5 5 8 13 27 14
3
解题思路:将所有西瓜总量算出,然后用深搜每次尝试用总和减去搜索到的部分和,每次进行最小值比较,
没想到用搜索做,纯属参考。。。
#include<stdio.h> #include<math.h> #include<stdlib.h> int a[21],sum,min,temp,n; void dfs(int step) { int i; if(abs(sum - 2 * temp) < min)//寻找最小值 min = abs(sum - 2 * temp);//2*temp代表有俩堆,我是这么理解的 if(step == n)//搜索结束 return ; for(i=step;i<n;i++) { temp += a[i];//尝试累计和 dfs(i+1); temp -= a[i];//回溯 } } int main() { int i; while(scanf("%d",&n)!=EOF) { sum = temp = 0; for(i=0;i<n;i++) { scanf("%d",&a[i]); sum += a[i]; } min = 99999; dfs(0); printf("%d\n",min); } return 0;}