动态规划 输出路径 hrbust1813

小乐乐要下山
Time Limit: 1000 MSMemory Limit: 32768 K
Total Submit: 440(178 users)Total Accepted: 219(166 users)Rating: Special Judge: No
Description
上学的路总是那么艰辛,在小乐乐辛苦的出了家门之后,她才想起自己的家已经搬到山上了(睡的真迷糊)。下山的路同样十分艰难,不同的地方通行的难易程度也不同。如图所示,小乐乐现在在山顶上,她面前有两条路,每条路通往一个地点,每个地点有一个值,表示这个通行的难易程度。最底层的地点就是山脚了。大家知道,小乐乐好懒好懒的,她想知道怎么下山最省力?
Input
第一行一个整数n(1<n<500)
随后n行,第i+1行有i个数字
表示山上的路况
Output
输出从山顶到山脚最省力的路。(保证答案唯一)
Sample Input
3
1
2 5
5 6 3
Sample Output
1 2 5
Hint

输入的是一个三角形,每个点能走到下面那个点和下右那个点。

#include<stdio.h>  
int Map[1005][1005];
  
int D[1005][1005];
  
int n;
  
int min(int a, int b)  
{
      
     if(a>b)  
          return b;
      
     return a;
      
}  
int main()  
{
      
     while(~scanf("%d",&n))  
         {
          
          for(int i = 1;  i <= n; i++)  
               for(int j = 1;  j <= i; j++)  
                    scanf("%d",&Map[i][j]);
          
          for(int i = 1;  i <= n;  i++)  
               D[n][i] = Map[n][i];
          
          for(int i = n-1; i >= 1;  i--)  
               for(int j = 1;  j <= n ; j++)   
                    D[i][j] = Map[i][j]+min(D[i+1][j],D[i+1][j+1]);
          printf("%d\t",Map[1][1]);
          
          int j=1;
          
          for(int i = 2;  i <= n;  i++) //记录路径  
        {

               int node = D[i - 1][j] - Map[i - 1][j];     
                if (node == D[i][j+1]) ++j;
                printf("%d\t",Map[i][j]);
              
              
        }    
    }  
}  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值