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)