📄 2633505_ac_62ms_312k.cc
字号:
#include<iostream>
using namespace std;
int num[64];
bool mg[64];
int n;
int cmp(const void *i, const void *j)
{
return *(int *)j - *(int *)i;
}
bool find(int m,int k,int len)
{
if(m==0 && k==0)
return true;
if(m==0)
m=len;
for(int i=0;i<n;i++)
{
if(!mg[i] && num[i]<=m)
{
mg[i]=true;
if(find(m-num[i],k-1,len))
return true;
mg[i]=false;
if (m <= num[i] || m == len)
return false;
}
}
return false;
}
int main()
{
int i,max,sum;
while(true)
{
scanf("%d",&n);
if(n==0)
break;
max=0;
sum=0;
for(i=0;i<n;i++)
{
scanf("%d",&num[i]);
sum=sum+num[i];
mg[i]=false;
}
qsort(num, n, sizeof(int), cmp);
for(int j=num[0];j<=sum;j++)
if((sum%j==0) && find(j,n,j))
{
cout<<j<<endl;
break;
}
}
system("pause");
return 0;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -