| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1749 人关注过本帖
标题:一个一维数组,选择一部分元素,它们可以分成和相等的两堆,求方法
只看楼主 加入收藏
青蝶
Rank: 2
等 级:论坛游民
帖 子:160
专家分:51
注 册:2018-2-4
结帖率:92%
收藏
已结贴  问题点数:20 回复次数:3 
一个一维数组,选择一部分元素,它们可以分成和相等的两堆,求方法
一个一维整型数组,取出一部分元素,这些元素恰好可以分成和相等的两堆,求不同和的个数。其中数组元素个数小于15。求大佬们提供一个思路。
搜索更多相关主题的帖子: 维数 选择 元素 相等 方法 
2018-06-19 21:41
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
收藏
得分:10 
程序代码:
#include <iostream>  
#include <vector>  
#include <numeric>  
using namespace std;  
struct Node  
{  
    bool reach;  
    int parent;   
    int value;  
      
    Node(): reach( false ), parent( 0 ), value( 0 )  
    {  
    }  
};  
int main()  
{  
    vector<int> seq;  
    for( int i; (cin >> i) && i; ) seq.push_back( i );  
      
    int allsum = accumulate( seq.begin(), seq.end(), 0 );  
    int partsum = allsum / 2;  
      
    vector<Node> f( partsum + 1 );  
    f[0].reach = true;  
    int rmpos = 0;  
      
    for( vector<int>::iterator it = seq.begin(); it != seq.end(); it++ )  
    {  
        bool rm = true;  
        for( int i = min(rmpos, partsum - *it); i >= 0; i-- )  
        {  
            if( !f[i].reach ) continue;  
            Node& next = f[i + *it];  
            next.reach = true;  
            if( !next.parent )  
            {  
                next.parent = i;  
                next.value = *it;  
            }  
            if( rm )  
            {  
                rmpos = max( rmpos, i + *it );  
                rm = false;  
            }  
        }  
    }  
      
    while( !f[partsum].reach ) partsum--;  
    cout << "The minimum difference of sums of two parts is " << allsum - partsum * 2 << endl;  
    cout << "The smaller part is: ";  
    for( int p = partsum; p != 0; p = f[p].parent ) cout << f[p].value << " ";  
    cout << endl;  
    return 0;  
}  
2018-06-19 23:14
lin5161678
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:45
帖 子:1136
专家分:3729
注 册:2011-12-3
收藏
得分:10 
回复 2楼 自学的数学
弄错了 编辑掉

[此贴子已经被作者于2018-6-20 00:03编辑过]


https://zh.
2018-06-19 23:45
lin5161678
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:45
帖 子:1136
专家分:3729
注 册:2011-12-3
收藏
得分:0 
求个数 所以 不管三七二十一 所有组合都得遍历一遍
15bit二进制模拟所有组合吧

比如
0表示不选择
1表示选择
数字10 对应二进制
000000000001010
arr[1] + arr[3]
看看符不符合要求
不符合就检查数字11对应二进制表示的组合

把结果除以2 就可以了

https://zh.
2018-06-19 23:57
快速回复:一个一维数组,选择一部分元素,它们可以分成和相等的两堆,求方法
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020330 second(s), 11 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved