利用dfs搜索,自己尝试想了好久没有理解,最后还是按照别人的题解写出来一份,中间有一些必要的剪枝优化
后面使用桶排序的思路,将原有代码大幅优化
#include <iostream>
#include <algorithm>
#include <queue>
#include <string>
#include <vector>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <string>
#include <stack>
#include <map>
#include <set>
using namespace std;
const int maxn= (1<<6)+3;
const int maxm= 53;
int n;
int stk[maxm];
int cmp(int lhs, int rhs)
{
return lhs> rhs;
}
int dfs(const int lth, int c_l, int res, int cnt)
{
--stk[c_l];
res-= c_l;
if (res){
for (int i= min(res, c_l); i> 0; --i){
if (stk[i] && dfs(lth, i, res, cnt+1)){
return 1;
}
}
}
else{
if (n== cnt){
return 1;
}
for (int i= 50; i> 0; --i){
if (stk[i]){
if (dfs(lth, i, lth, cnt+1)){
return 1;
}
break;
}
}
}
++stk[c_l];
return 0;
}
int Search(const int sum, const int mx)
{
const int h_sum= sum>>1;
for (int i= mx; i<= h_sum; ++i){
if (sum%i){
continue;
}
if (dfs(i, mx, i, 1)){
return i;
}
}
return sum;
}
int main(int argc, char const *argv[])
{
int sum;
int x, mx;
while (~scanf("%d", &n) && n){
sum= mx= 0;
memset(stk, 0, sizeof(stk));
for (int i= 0; i< n; ++i){
scanf("%d", &x);
if (x> mx){
mx= x;
}
sum+= x;
++stk[x];
}
printf("%d\n", Search(sum, mx));
}
return 0;
}