这个题目意思虽然很容易明白,但是操作起来很难符合题解,写了几个都没对,费了很长时间用暴力勉强80分,后来参考大佬代码,惊叹真妙,话不多说下面是修改过的代码
这个代码的思路是将数组中9个元素全部初始化为零
然后将三个数的个十百位变为数组下标,
然后令每个下标赋值为零,
以倍数为前提条件令不同下标的值都赋值为1,
当数组中的9个元素相加为9,说明每个下标都不相同,
而且又符合倍数条件
#include <stdio.h>
int main (void)
{
int i, a[10], j, sum=0, k, m;
for (i=123; i*3<987; i++)//因为题设要求组合不能为重复数字
{
for (m=0; m<10; m++)
a[m]=0;
a[i/100]=1;
a[i/10%10]=1;
a[i%10]=1;
j=i*2;
a[j/100]=1;
a[j/10%10]=1;
a[j%10]=1;
k=i*3;
a[k/100]=1;
a[k/10%10]=1;
a[k%10]=1;
for (sum=0, m=1; m<10; m++)
sum +=a[m];
if (sum==9)
printf ("%d %d %d\n", i, j, k);
}
return 0;
}