Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
133613 | | 最大子序和 | C++ | 通过 | 100 | 0 MS | 244 KB | 344 | 2024-03-02 08:34:31 |
#include <bits/stdc++.h> using namespace std; int a,b[110],f[110]; int dfs(int n){ if(f[n]!=-1) return f[n]; return f[n]=max(dfs(n-1)+b[n],b[n]); } int main(){ memset(f,-1,sizeof(f)); cin>>a; for(int i=1;i<=a;i++){ cin>>b[i]; } dfs(a); int maxa=-999; for(int i=1;i<=a;i++){ maxa=max(maxa,f[i]); } cout<<maxa; }