HDU 4540 威威猫系列故事——打地鼠(树塔问题简单变形)
2015-09-10 22:51
417 查看
题目地址:点击打开链接
思路:水题,第一次投TLE了,结果改了一下,也TLE了,结果是忘了加!=EOF了,看上面TLE的那个代码也忘加了,加上之后也过了,把2个都贴一下吧
AC代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <stack>
#include <map>
#include <cstring>
#include <climits>
#include <cmath>
using namespace std;
int dp[25][510];
int main()
{
int n,m,k;
int i,j,l,min1;
while(scanf("%d%d",&n,&k) != EOF)
{
memset(dp,0,sizeof(dp));
for(i=1; i<=k; i++)
{
scanf("%d",&m);
dp[1][m] = 1;
}
for(i=2; i<=n; i++)
{
for(j=1; j<=k; j++)
{
scanf("%d",&m);
min1 = INT_MAX;
for(l=1; l<=500; l++)
{
if(dp[i-1][l] && dp[i-1][l] + abs(m-l) < min1)
{
min1 = dp[i-1][l] + abs(m-l);
}
}
dp[i][m] = min1;
}
}
min1 = INT_MAX;
for(i=1; i<=500; i++)
{
if(dp
[i] && dp
[i] < min1)
min1 = dp
[i];
}
printf("%d\n",min1-1);
}
return 0;
}
这个代码不如第二个效率高,数据多点就真的TLE了
AC代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <stack>
#include <map>
#include <cstring>
#include <climits>
#include <cmath>
using namespace std;
int dp[25][15],a[25][15];
int main()
{
int n,m,k;
int i,j,l,min1;
while(scanf("%d%d",&n,&k) != EOF)
{
memset(dp,0,sizeof(dp));
for(i=1; i<=k; i++)
{
scanf("%d",&m);
a[1][i] = m;
}
for(i=2; i<=n; i++)
{
for(j=1; j<=k; j++)
{
scanf("%d",&m);
a[i][j] = m;
min1 = INT_MAX;
for(l=1; l<=k; l++)
{
if(dp[i-1][l] + abs(m-a[i-1][l]) < min1)
{
min1 = dp[i-1][l] + abs(m-a[i-1][l]);
}
}
dp[i][j] = min1;
}
}
min1 = INT_MAX;
for(i=1; i<=k; i++)
{
if(dp
[i] < min1)
min1 = dp
[i];
}
printf("%d\n",min1);
}
return 0;
}
思路:水题,第一次投TLE了,结果改了一下,也TLE了,结果是忘了加!=EOF了,看上面TLE的那个代码也忘加了,加上之后也过了,把2个都贴一下吧
AC代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <stack>
#include <map>
#include <cstring>
#include <climits>
#include <cmath>
using namespace std;
int dp[25][510];
int main()
{
int n,m,k;
int i,j,l,min1;
while(scanf("%d%d",&n,&k) != EOF)
{
memset(dp,0,sizeof(dp));
for(i=1; i<=k; i++)
{
scanf("%d",&m);
dp[1][m] = 1;
}
for(i=2; i<=n; i++)
{
for(j=1; j<=k; j++)
{
scanf("%d",&m);
min1 = INT_MAX;
for(l=1; l<=500; l++)
{
if(dp[i-1][l] && dp[i-1][l] + abs(m-l) < min1)
{
min1 = dp[i-1][l] + abs(m-l);
}
}
dp[i][m] = min1;
}
}
min1 = INT_MAX;
for(i=1; i<=500; i++)
{
if(dp
[i] && dp
[i] < min1)
min1 = dp
[i];
}
printf("%d\n",min1-1);
}
return 0;
}
这个代码不如第二个效率高,数据多点就真的TLE了
AC代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <stack>
#include <map>
#include <cstring>
#include <climits>
#include <cmath>
using namespace std;
int dp[25][15],a[25][15];
int main()
{
int n,m,k;
int i,j,l,min1;
while(scanf("%d%d",&n,&k) != EOF)
{
memset(dp,0,sizeof(dp));
for(i=1; i<=k; i++)
{
scanf("%d",&m);
a[1][i] = m;
}
for(i=2; i<=n; i++)
{
for(j=1; j<=k; j++)
{
scanf("%d",&m);
a[i][j] = m;
min1 = INT_MAX;
for(l=1; l<=k; l++)
{
if(dp[i-1][l] + abs(m-a[i-1][l]) < min1)
{
min1 = dp[i-1][l] + abs(m-a[i-1][l]);
}
}
dp[i][j] = min1;
}
}
min1 = INT_MAX;
for(i=1; i<=k; i++)
{
if(dp
[i] < min1)
min1 = dp
[i];
}
printf("%d\n",min1);
}
return 0;
}
相关文章推荐
- iCheat 使用教程
- hdoj 2122Ice_cream’s world III 【最小生成树 kruskal && prim】
- Android 监听apk安装替换卸载广播的实现代码
- JS常用正则表达式
- C++的构造函数和析构函数
- ANGULAR JS PROMISE使用
- uva 10510 - Cactus(仙人掌图)
- 京东众筹双色球中奖号计算方法
- 【oracle案例】ORA-01102: cannot mount database in EXCLUSIVE mode
- Queue(队列) Stack(堆栈)
- 零基础学python-15.3 函数的定义、调用与多态
- Missing number - 寻找缺失的那个数字
- 零基础学python-15.3 函数的定义、调用与多态
- 第一百六十一天 how can I 坚持
- 麻将胡牌判决
- PM2.5检测仪设计
- Win7x64+VS2012+OpenCV2.4.3+CMake2.8.10+TBB41重编译OpenCV
- html行内元素 和 块状元素 总结
- 面试必备:文本框与按钮的最简组合
- 0909对编译原理的理解