Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
113343 | 爱新觉罗·赵文卿·传统美德 | 分割等和子集 | C++ | 通过 | 100 | 0 MS | 252 KB | 424 | 2023-12-02 09:48:19 |
#include<bits/stdc++.h> using namespace std; int V,n; int v[100001]; int dp[100001]; int main(){ cin>>n; for(int i=1;i<=n;i++){ cin>>v[i]; V+=v[i]; } for(int i=1;i<=n;i++){ for(int j=V;j>=v[i];j--){ dp[j]=max(dp[j],max(dp[j-1],dp[j-v[i]]+v[i])); } } if(V%2==0&&dp[(V/2)]==V/2) cout<<"true"<<endl; else cout<<"false"; return 0; }