标题:石头归并问题
取消只看楼主
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
 问题点数:0 回复次数:9 
石头归并问题

转载:大家又没有比较好的思路阿!借鉴一下

Problem

你有一堆石头质量分别为W1,W2,W3...WN.(W<=100000)现在需要你将石头合并为两堆,使两堆质量的差为最小。

Input

该程序有多组测试数据,每组测试数据第一行为整数N(1<=N<=20),表示有N堆石子。接下去N行,为每堆石子的质量。

Output

每组测试数据只需输出合并后两堆的质量差的最小值。

Sample Input

5
5
8
13
27
14
2
4
4

Sample Output

3
0

搜索更多相关主题的帖子: 石头 
2006-05-02 17:20
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 

三楼回答的非常对

2006-05-02 20:09
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 
用递归的方法
1.我感觉把每个相邻的相减
得到一组数
2.然后把这组数按1处理
不知四楼按1处理是何意思
2006-05-02 20:29
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 
大家都来集思广益阿
快来顶!
2006-05-02 21:45
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 
以下是引用ninanwine在2006-5-3 3:10:00的发言:

求和的一半SUM,然后数组前N项相加当和大于SUM时将此N项赋予新数组B,余下的给数组C,求B的和SUMB,T=SUM-SUMB;B中元素和C中元素求差值为N当T>N>0时交换两个元素,如B中元素<T,将此元素赋予C,B中变成0;循环!

我觉的T = SUMB - SUM这样才大于0
11楼算法挺好,值得借鉴

2006-05-03 10:58
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 
以下是引用ninanwine在2006-5-3 3:10:00的发言:

求和的一半SUM,然后数组前N项相加当和大于SUM时将此N项赋予新数组B,余下的给数组C,求B的和SUMB,T=SUM-SUMB;B中元素和C中元素求差值为N当T>N>0时交换两个元素,如B中元素<T,将此元素赋予C,B中变成0;循环!

我觉得T = SUMB - SUM
11楼算法比较好,值得借鉴

2006-05-03 11:01
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 
15楼说错了,还是11楼的对
2006-05-03 18:18
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 
15楼好像不对
还是11楼的对
2006-05-03 18:48
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 
15楼的好像不对,还是11楼的对
2006-05-03 18:49
youxiaxyz
Rank: 1
等 级:新手上路
帖 子:85
专家分:0
注 册:2006-4-5
得分:0 

按11楼的想法我写了一个程序,请诸位测试
#include<stdio.h>

int main()
{
int i, j, k, p, tag, n, a[100], b[100], c[100];
float t, sum, sumb;
scanf("%d", &n);

while(n) {

sum = 0; sumb = 0;
for(i = 0; i < n; i++) {
scanf("%d", &a[i]);
sum +=a[i];
}

for(i = 0; sumb < sum / 2; i++) {
b[i] = a[i];
sumb += b[i];
}//当大于一半sum时赋给数组b

tag = i;//记录数组b的个数

for(j = 0; i < n; i++, j++)
c[j] = a[i];
t = sumb - sum / 2;//记录数组b与平均数的差值

for(j = 0; j < tag; j++)
for(k = 0; k < n - tag; k++) {
if((b[j] - c[k]) >0 && (b[j] - c[k]) < t) {
t = t - b[j] + c[k];
p = b[j];
b[j] = c[k];
c[k] = p;
j--;
break;
}
if(b[j] < t) {
c[n - tag] = b[j];
t = t - b[j];
for(p = j; p < tag - 1; p++)
b[p] = b[p + 1];
b[p] = 0;
tag--; j--;
break;
}//如果数组b中的值小于t将它给c并且b中值为0或者b中值大于0且小于t则交换
}

printf("%d\n", (int)(2 * t));
scanf("%d", &n);

}
return 0;
}

2006-05-03 18:53



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-61592-1-1.html




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

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