提交时间:2024-05-18 16:23:36

运行 ID: 147578

#include<iostream>8 using namespace std; int a[101]; int dp[101][10001]; int main(){ int n,sum=0; cin>>n; int m=n>>1; for(int i=1;i<=n;i++){ cin>>a[i]; sum+=a[i]; } int V=sum>>1; dp[0][0]=true; for(int i=1;i<=n;i++){ for(int j=m;j>=1;j--){ for(int k=V;k>=a[i];k--){ dp[j][k]=(dp[j][k] || dp[j-1][k-a[i]]); } } } for(int i=V;i>=0;i--){ if(dp[m][i]){ cout<<i<<endl; break; } } return 0; }