N个数划分两组,差最小

来源:互联网 发布:u盘在mac上不显示文件 编辑:程序博客网 时间:2024/05/29 16:35

思路,01背包解决,复杂度O(w*n)

/** 20171127*/#include <cstdio>#include <cstring>#include <algorithm>int n;int num[400];int dp[200][400];//w nint main(){    memset(dp,0,sizeof(dp));    scanf("%d",&n);    for(int i=1;i<=n;i++) scanf("%d",&num[i]);    for(int i=1;i<=180;i++)    {        for(int j=1;j<=n;j++)        {            if(num[j]<=i)            {                dp[i][j] = std::max(dp[i-num[j]][j-1]+num[j],dp[i][j-1]);            }else            {                dp[i][j] = dp[i][j-1];            }            dp[i][j] = std::max(dp[i][j],dp[i-1][j]);        }    }    for(int i=1;i<=n;i++)    {        for(int j=0;j<=180;j+=10)            printf("%3d ",dp[j][i]);        printf("\n");    }        int ans = 0;    for(int i=1;i<=180;i++) ans = std::max(ans,dp[i][n]);    printf("%d\n",(180-ans)*2);    return 0;}
阅读全文
0 0
原创粉丝点击