注:C语言练习100天这个专栏 摘抄自菜鸟教程。我写在这里印象更深,练习自用的。有些地方会加入一些自己的思考。
题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
自己先想想~
1 2 3 4 互不相同且无重复 三位数
程序分析: 可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。
实例
#include<stdio.h>
int 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++) { // 确保i、j、k三位互不相同
if (i!=kjk) {
printf("%d,%d,%d\n",i,j,k);
}
}
}
}
}
给出的参考答案是一般都能想到的,自己也还可以想想怎么优化
以上实例输出结果为:
1,2,3
1,2,4
1,3,2
1,3,4
1,4,2
1,4,3
2,1,3
2,1,4
2,3,1
2,3,4
2,4,1
2,4,3
3,1,2
3,1,4
3,2,1
3,2,4
3,4,1
3,4,2
4,1,2
4,1,3
4,2,1
4,2,3
4,3,1
4,3,2