古堡算式
福尔摩斯到某,看到门上写着一个奇怪的算式:
ABCDE * ? = EDCBA
他对华生说:“ABCDE应该代表不同的数字,问号也代表某个数字!”
华生:“我猜也是!”
于是,两人沉默了好久,还是没有算出合适的结果来。
请你利用计算机的优势,找到破解的答案。
把 ABCDE 所代表的数字写出来。
程序代码:int main()
{
int in; //ABCDE
int out; //EDCBA
int k; // ?
int a[5] = {0}; // 各位数字:A B C D E
for(in=10000; in<=99999; in++)
{
out = 0;
k = 1;
int i =0;
int tmp = in;
//ABCDE -> EDCBA
do{
a[i++] = tmp%10;
out = out*10 + (tmp%10);
}while(0 != (tmp=tmp/10));
if(!(a[0]^a[1] && a[0]^a[2] && a[0]^a[3] && a[0]^a[4] && a[1]^a[2] && a[1]^a[3] && a[1]^a[4] && a[2]^a[3] a[2]^a[4] && a[3]^a[4]))
continue;
while((in*k) < out)
{
k++;
}
if((in*k) == out)
{
printf("%d * %d = %d\n", in, k, out);
}
}
return 0;
}
贴上代码,求大神点评