首页 > 编程语言 > 详细

算法(三)

时间:2018-05-30 23:57:04      阅读:317      评论:0      收藏:0      [点我收藏+]

一、

技术分享图片

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int Min = 1e10;
int num;
int sum = 0;
int res;

void dfs(vector<int>& stone, int w, int start, int cnt) {
 if (cnt == num) {
  if (abs(w * 2 - sum) < Min) {
   res = w;
   Min = abs(w * 2 - sum);
  }
 }
 else {
  if (start == stone.size()) return;
  dfs(stone, w, start + 1, cnt);
  dfs(stone, w + stone[start], start + 1, cnt + 1);  
 }
}

int main()
{
 int n;
 cin >> n;
 vector<int> stone(n);
 for (int i = 0; i < n; i++) {
  cin >> stone[i];
  sum += stone[i];
 }
 num = n / 2;
 sort(stone.begin(), stone.end());
 dfs(stone, 0, 0, 0);
 if (res * 2 > sum) cout << sum - res << " " << res << endl;
 else cout << res << " " << sum - res << endl;
    return 0;
}

  

 

算法(三)

原文:https://www.cnblogs.com/ruo-li-suo-yi/p/9114038.html

(1)
(1)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!