HDU 4540 威威猫系列故事——打地鼠
【摘要】 题目链接~~>
做题感悟:这题第一次做是在圣诞大战时做的,当时没做出来,现在想想真是弱爆了!(动态规划是硬伤!)也许是当时比赛气氛不一样。
解题思路:其实和暴力差不多。一层一层的暴力。假设有 n 行 m 列,把数存入 g 数组中,最优解存入F中。
 ...
做题感悟:这题第一次做是在圣诞大战时做的,当时没做出来,现在想想真是弱爆了!(动态规划是硬伤!)也许是当时比赛气氛不一样。
解题思路:其实和暴力差不多。一层一层的暴力。假设有 n 行 m 列,把数存入 g 数组中,最优解存入F中。
动态方程:F[ i ][ j ] = min( abs ( g [ i ][ j ] - g [ i - 1 ][ j ] ) + F[ i ][ i - 1 ] ) (0 <= j < m , 1 <= i < n) ;
代码:
-
#include<stdio.h>
-
#include<iostream>
-
#include<map>
-
#include<string>
-
#include<string.h>
-
#include<stdlib.h>
-
#include<math.h>
-
#include<queue>
-
#include<algorithm>
-
using namespace std ;
-
int main()
-
{
-
int n,m ;
-
int g[50][50] ;
-
int b[50][50] ;
-
while(~scanf("%d%d",&n,&m))
-
{
-
memset(b,0,sizeof(b)) ;
-
for(int i=0 ;i<n ;i++)
-
for(int j=0 ;j<m ;j++)
-
scanf("%d",&g[i][j]) ;
-
int min,mx ;
-
for(int i=1 ;i<n ;i++)
-
for(int j=0 ;j<m ;j++)
-
{
-
min=abs(g[i-1][0]-g[i][j])+b[i-1][0] ;
-
for(int k=1 ;k<m ;k++)
-
{
-
mx=abs(g[i-1][k]-g[i][j])+b[i-1][k] ;
-
min=min < mx ? min : mx ;
-
}
-
b[i][j]=min ;
-
}
-
min=b[n-1][0] ;
-
for(int i=1 ;i<m ;i++)
-
min = min < b[n-1][i] ? min : b[n-1][i] ;
-
printf("%d\n",min) ;
-
}
-
return 0 ;
-
}
文章来源: blog.csdn.net,作者:Linux猿,版权归原作者所有,如需转载,请联系作者。
原文链接:blog.csdn.net/nyist_zxp/article/details/19677987
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)