题干:
给定不超过6的正整数A,考虑从A开始的连续4个数字,请输出所有由它们组成的无重复数字的3位数。
输入格式:
输入在一行中给出A
标题
输出格式:
输出满足条件的三位数,要求从小到大,每行6个整数。整数间以空格分隔,但行末不能有多余空格
输入样例:
2
输出样例:
234 235 243 245 253 254
324 325 342 345 352 354
423 425 432 435 452 453
523 524 532 534 542 543
*while循环
#include<stdio.h>
int main() {
int i, j, k, A; // i j k 代表 百 十 个位
int cnt=0; //cnt 计数
scanf("%d", &A);
i=A;
while(i<=A+3) { //i,j,k <=A+3 表示 i,j,k只用 A 后连续的四个数字组成三位数
//i=A,J=A.K=A, 每次让三位从开始往后查找,找一次各自+1
// 例如:A=2, 查找从222~555
//用if条件筛掉其中互相重复的数字, 当互相不重复才printf
j=A;
while(j<=A+3) {
k=A;
while(k<=A+3) {
if (i!=j) { //百位十位不能重复
if (i!=k) { //百位个位不能重复
if(j!=k) { //十位个位不重复
cnt++ ; //每找到一个符合条件的数就计数+1
printf("%d%d%d", i,j,k);
if (cnt==6) {
printf("\n"); //当计数到6时换行
cnt=0; //换行后重新计数,计数器清零,再循环
} else printf(" ");
}
}
}
k++;
}
j++;
}
i++;
}
return 0;
}
for循环
#include<stdio.h>
int main()
{
int i, j, k, A, count;
scanf("%d", &A);
for (i=A; i<=A+3; i++){
count = 0;
for (j=A; j<=A+3; j++){
if (j!=i){
for(k=A; k<=A+3; k++){
if (k!=i && k!=j){
count ++;
if (count==6) printf("%d", i*100+j*10+k);
else printf("%d ", i*100+j*10+k);
}
}
}
}
printf("\n");
}
return 0;
}