题目:给定不超过6的正整数A,考虑从A开始的连续四个数字(递增),请输出所有由它们组成的无重复数字的三位数。要求从小到大,每行6个整数,整数之间有空格隔开,行末没有空格。
编程思路分析:
- 输入一个数字a。得到2、3、4、5。
- 将2、3、4、5遍历组合。
- 添加题目所要求格式并输出结果。
重点运算思路:
- 题目所说输入小于6的数字 → 添加一个if判断语句。
- 将2、3、4、5遍历组合实际上只需要3个变量,因为我们输出的结果是3个数组合。组合发现每个变量都需要在变化中组合,所以可以使用嵌套循环,嵌套3个循环以达成三个变量动态对比的目的。
- 在最内部的循环中添加一个if语句以判断:当3个数字不相同时可以输出。
- 最后格式可以添加一个计数器cnt(变量),运用if语句判断:当cnt == 6时,输出回车,否则输出空格。
实现代码如下:
#include <stdio.h>
/*a = 4; 4 5 6 7
4在前:4...
5在前:5...
6在前:6...
7在前:7...排列顺序:从小到大,数字中间有空格,最后一位没有空格。
*/
#include <stdio.h>int main(){
int a;
int i, j, k;
int cnt = 0;
scanf("%d", &a);
if(a<6){
for(i=a; i<=a+3; i++){
for(j=a; j<=a+3; j++){
for(k=a; k<=a+3; k++){
if(i!= j && i!= k && j!=k){
cnt++;
printf("%d%d%d", i, j, k);
if(cnt == 6){
printf("\n");
cnt = 0;
}else{
printf(" ");
}
}
}
}
}
}else{
printf("请输入小于6的数");
}
return 0;
}