有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
我的解决
#include <stdio.h>
int main()
{
int m,g,s,b,i=0;
for(m=100;m<=999;m++)
{
g=m%10;
s=m/10%10;
b=m/100;
if(g<=4&&g>=1&&s<=4&&s>=1&&b<=4&&b>=1)
{
printf("%d\t",m);
i++;
}
}
printf("\n The have %d numbers.\n",i);
return 0;
}
答案的解决
#include <stdio.h>
main()
{
int i,j,k;
printf("\n");
for(i=1;i<5;i++) /*以下为三重循环*/
for(j=1;j<5;j++)
for (k=1;k<5;k++)
{
if (i!=k&&i!=j&&j!=k) /*确保i、j、k三位互不相同*/
printf("%d,%d,%d\n",i,j,k);
}
}
分析:答案这个能使无效数字更少,计算更快。