zoukankan      html  css  js  c++  java
  • 数字三角形

    程序设计导引及在线实践

    第一种解法,直接递归,优化后,改为逆推动态规划

    打印路径,可以反过来计算。


    #include<iostream>
    using namespace std;
    #define MAX_NUM 100
    int A[MAX_NUM + 10][MAX_NUM + 10];
    int D[MAX_NUM + 10][MAX_NUM + 10];
    int N;

    void print_path()
    {
         int i=1,j=1;
         printf("%d ", A[i][j]);
        
         for(i = 1; i < N; )
         {
             if(D[i][j]==D[i+1][j+1]+A[i][j])
                 j=j+1;
             i++;
             printf("%d ", A[i][j]);   
         }
         printf(" ");

    }
    int main()
    {
         int m;
         scanf("%d", &N);
         for( int i = 1; i <= N; i ++ )
             for( int j = 1; j <= i; j ++ )
                 scanf("%d", &A[i][j]);

        for(int i=1;i<=N;i++)
         {
             D[N][i]=A[N][i];
         }
         for(int i=N-1;i>=1;i--)
         {
             for( int j = 1; j <= i; j ++ )
                 D[i][j]=max(D[i+1][j], D[i+1][j+1]) + A[i][j];
         }
         printf("%d ", D[1][1]);
         print_path();   
         return 0;
    }


    另一种是计算时候就保存方向,加一个数组保存相关信息

    #include<iostream>
    using namespace std;
    #define MAX_NUM 100
    int A[MAX_NUM + 10][MAX_NUM + 10];
    int D[MAX_NUM + 10][MAX_NUM + 10];
    int dir[MAX_NUM + 10][MAX_NUM + 10];//保存方向
    int N;

    void print_path()
    {
         int i=1,j=1;
         printf("%d ", A[i][j]);
        
         for(i = 1; i < N; )
         {
             if(D[i][j]==D[i+1][j+1]+A[i][j])
                 j=j+1;
             i++;
             printf("%d ", A[i][j]);   
         }
         printf(" ");

    }


    void print_path2()
    {
         int i=1,j=1;
         //printf("%d ", A[i][j]);
        
         for(i = 1; i <=N; )
         {
             printf("%d ", A[i][j]);   
             j+=dir[i][j];
             i++;   
         }
         printf(" ");

    }
    int main()
    {
         int m;
         scanf("%d", &N);
         for( int i = 1; i <= N; i ++ )
             for( int j = 1; j <= i; j ++ )
                 scanf("%d", &A[i][j]);

        for(int i=1;i<=N;i++)
         {
             D[N][i]=A[N][i];
         }
         for(int i=N-1;i>=1;i--)
         {
             for( int j = 1; j <= i; j ++ )
             {
                 if(D[i+1][j] > D[i+1][j+1])
                 {
                     D[i][j]=D[i+1][j] + A[i][j];
                     dir[i][j]=0;
                 }
                 else
                 {
                     D[i][j]=D[i+1][j+1] + A[i][j];
                     dir[i][j]=1;    
                 }
                
             }
                
         }
         printf("%d ", D[1][1]);
         print_path();
         print_path2();   
         return 0;
    }

  • 相关阅读:
    【Android】4.1 UI设计器
    【Android】4.0 Android项目的基本结构
    【Android】3.25 示例25--调启百度地图
    【Android】3.24 示例24--OpenGL绘制功能
    【Android】3.23 示例23--瓦片图功能
    【Android】3.22 示例22--LBS云检索功能
    【Android】3.21 示例21—兴趣点收藏功能
    【Android】3.20 示例20—全景图完整示例
    【Android】3.19 示例19--全景图HelloWorld
    Java并发编程之happens-before
  • 原文地址:https://www.cnblogs.com/cute/p/15263222.html
Copyright © 2011-2022 走看看