职业摆烂人


私信TA

用户名:uq_59495985965

访问量:6082

签 名:

等  级
排  名 892
经  验 3389
参赛次数 0
文章发表 18
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

解题思路:
在二维数组中a[i][j]+a[i+1][j]<a[i+1][j+1]+a[i][j],取大的,从倒数第二行开始与后一行相加,往前推。
注意事项:

参考代码:

#include<iostream>
#include<cstring>
using namespace std;
int main()
{
    int t;
    cin>>t;
    while(t--)
    {
        int a[100][100],n;
        cin>>n;
        memset(a,0,sizeof(a));
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<i+1;j++)
            {
                cin>>a[i][j];
            }
        }
        for(int i=n-2;i>=0;i--)
        {
            for(int j=i;j>=0;j--)
            {
                if(a[i][j]+a[i+1][j]<a[i+1][j+1]+a[i][j])
                {
                    a[i][j]=a[i+1][j+1]+a[i][j];
                }
                else
                {
                    a[i][j]=a[i][j]+a[i+1][j];
                }
            }
        }
        cout<<a[0][0]<<endl;
        // for(int i=0;i<n;i++)检查是否正确
        // {
        //     for(int j=0;j<i+1;j++)
        //     {
        //         cout<<a[i][j]<<" ";
        //     }
        //     cout<<endl;
        // }
    }
    return 0;
}


 

0.0分

1 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答

代码解释器

  评论区