标签:cstring appear use within sub ogr pop 代码 open
1 ABCDEFGHIJKL 11700519 ZAYEXIWOVU 3072997 SOUGHT 1234567 THEQUICKFROG 0 END
LKEBA YOXUZ GHOST no solution
1.lexicographical order:cap < card < cat < to < too< two < up
2.事实上是个组合问题12*11*10*9*8大约十几万次当然5个循环不超时。用搜索的形式写的时候由于递归和回溯耗时,所以超时
3.代码:
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int t;
char s[20];
int a[10];
int len;
bool flag;
int cmp(int a,int b)
{
return a>b;
}
void Find()
{
for(int i=1; i<=len; i++)
{
a[1]=s[i]-‘A‘+1;
for(int j=1; j<=len; j++)
{
if(i==j)
continue;
a[2]=s[j]-‘A‘+1;
for(int k=1; k<=len; k++)
{
if(j==k||k==i)
continue;
a[3]=s[k]-‘A‘+1;
for(int l=1; l<=len; l++)
{
if(l==k||l==j||l==i)
continue;
a[4]=s[l]-‘A‘+1;
for(int m=1; m<=len; m++)
{
if(m==l||m==k||m==j||m==i)
continue;
a[5]=s[m]-‘A‘+1;
if(a[1]-a[2]*a[2]+a[3]*a[3]*a[3]-a[4]*a[4]*a[4]*a[4]+a[5]*a[5]*a[5]*a[5]*a[5]==t)
{
flag=1;
break;
}
}
if(flag)
break;
}
if(flag)
break;
}
if(flag)
break;
}
if(flag)
break;
}
}
int main()
{
while(scanf("%d%s",&t,s+1)==2)
{
if(t==0&&strcmp("END",s+1)==0)
{
break;
}
else
{
len=strlen(s+1);
flag=0;
sort(s+1,s+1+len,cmp);//保证答案是字典序上最大
Find();
if(flag)
printf("%c%c%c%c%c\n",a[1]+‘A‘-1,a[2]+‘A‘-1,a[3]+‘A‘-1,a[4]+‘A‘-1,a[5]+‘A‘-1);
else
printf("no solution\n");
}
}
return 0;
}
HDU 1015 Safecracker(第一次用了搜索去遍历超时,第二次用for循环能够了,思路一样的)
标签:cstring appear use within sub ogr pop 代码 open
原文地址:http://www.cnblogs.com/lxjshuju/p/7141205.html