数字塔问题

cpp 复制代码
#include<iostream>
using namespace std;
//从下向上得到最优值
void dtower(int a[][100],int s[][100],int n)
{
    for(int i=n; i>=1; i--)
    {
        for(int j=1; j<=i; j++)
        {
            if(i==n)
                s[i][j]=a[i][j];
            else
            {
                int t=s[i+1][j];
                if(t<s[i+1][j+1])
                    t=s[i+1][j+1];
                s[i][j]=a[i][j]+t;
            }

        }
    }
}
void Traceback(int a[][100],int s[][100],int n,int i,int j)
{
    if(i==n)
        cout<<i<<" "<<j<<endl;
    else
    {
        cout<<i<<" "<<j<<endl;
        if(s[i][j]==a[i][j]+s[i+1][j])
            Traceback(a,s,n,i+1,j);
        else
            Traceback(a,s,n,i+1,j+1);
    }
}
int main()
{
    int n;cin>>n;
    int a[100][100]={0},s[100][100]={0};
    for(int i=1;i<=n;i++)
        for(int j=1;j<=i;j++)
        cin>>a[i][j];

    dtower(a,s,n);
    cout<<"s[i][j]:"<<endl;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=i;j++)
            cout<<s[i][j]<<" ";
        cout<<endl;
    }

    Traceback(a,s,n,1,1);
    return 0;
}

5

30

23 21

20 13 10

7 12 10 22

4 5 2 6 5

相关推荐
小字节,大梦想29 分钟前
【C++】二叉搜索树
数据结构·c++
吾名招财30 分钟前
yolov5-7.0模型DNN加载函数及参数详解(重要)
c++·人工智能·yolo·dnn
我是哈哈hh1 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
憧憬成为原神糕手1 小时前
c++_ 多态
开发语言·c++
郭二哈1 小时前
C++——模板进阶、继承
java·服务器·c++
Tisfy1 小时前
LeetCode 2187.完成旅途的最少时间:二分查找
算法·leetcode·二分查找·题解·二分
挥剑决浮云 -1 小时前
Linux 之 安装软件、GCC编译器、Linux 操作系统基础
linux·服务器·c语言·c++·经验分享·笔记
Mephisto.java1 小时前
【力扣 | SQL题 | 每日四题】力扣2082, 2084, 2072, 2112, 180
sql·算法·leetcode
robin_suli1 小时前
滑动窗口->dd爱框框
算法
丶Darling.1 小时前
LeetCode Hot100 | Day1 | 二叉树:二叉树的直径
数据结构·c++·学习·算法·leetcode·二叉树