找到最小和分区的子集

问题描述

这是我使用DP进行最小和分区的代码

#include<bits/stdc++.h>
using namespace std;
int minPart(vector<int>v)
{
  int sum = accumulate(v.begin(),v.end(),0);
  bool dp[v.size()+1][sum+1];
  fill(*dp,*dp+(v.size()+1)*(sum+1),false);
  for(int i=0;i<=v.size();i++)
  {
    dp[i][0]=true;
    for(int j=1;i>0 && j<=sum;j++)
    {
      dp[i][j]=dp[i-1][j];
      if(v[i-1]<=j)
        dp[i][j] |= dp[i-1][j-v[i-1]];
    }
  }
  int j = sum/2;
  while(j>=0 && !dp[v.size()][j]){
    j--;
  }
  return sum-2*j;
}
int main()
{
  vector<int> v = {10,20,15,5,25};
  cout<<minPart(v)<<endl;
  return 0;
}

我还想找到导致总和最小的子集。

例如对于集合{1,6,11,5},最小差异为1,子集的差异为{1,6} {11}。我想同时打印子集的{1,6},{11}。

有什么有效的方法可以找到导致最小总和差的两个子集的印刷品吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)