szlh_XJS @ 2024-02-14 21:42:37
#include <bits/stdc++.h>
using namespace std;
int nn[1005][1005];
int n,s;
int main()
{
cin>>n;
nn[1][0]=1;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=i;j++)
{
cin>>nn[i][j];
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=i;j++)
{
nn[i][j]=nn[i][j]+max(nn[i-1][j],nn[i-1][j-1]);
}
}
for(int i=1;i<=n;i++)
{
s=max(s,nn[n][i]);
}
cout<<s;
return 0;
}
by Tim0509 @ 2024-02-14 21:48:11
nn[1][0]=1;
为什么要加这一行
by sading @ 2024-02-14 22:03:52
楼上说的对,人家0就是0不要凭空给一个数啊
by LeoYangcz @ 2024-02-23 22:17:55
#include<bits/stdc++.h>
using namespace std;
int s[1005][1005];
int main(){
int n;
cin>>n;
for(int i=1;i<=n;i++){
for(int j=1;j<=i;j++){
cin>>s[i][j];
}
}
for(int i=n;i>=1;i--){
for(int j=i;j>=1;j--){
s[i][j]+=max(s[i+1][j],s[i+1][j+1]);
}
}
cout<<s[1][1];
return 0;
}