求符合给定条件的整数集
给定不超过6的正整数A,考虑从A开始的连续4个数字。请输出所有由它们组成的无重复数字的3位数。
输入格式:
输入在一行中给出A。
输出格式:
输出满足条件的的3位数,要求从小到大,每行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
思路分析:
问题:
- 如何找到不同的三位数且按大小排列;
- 如何满足格式要求,满6换行,每个数后有空格,行末尾不算;
解决:
- 三次循环,用if语句找到不同的数,因为if是递增的,所以输出的数也是直接有序的; 三位数 = i*100 +j*10+k;
- 添加一个count计数器,count%6 == 0,则为满六,满六输出换行,不满则输出空格;
实现代码:
int main(){
int key;
int count = 0; //计数,用于解决格式空格和换行
scanf("%d",&key);
for(int i= key;i<=key+3;i++){
for(int j= key;j<=key+3;j++){
for(int k= key;k<=key+3;k++){
if(i != j&& i != k & j != k){ //找到不同的三位数
printf("%d",i*100+j*10+k);
count++;
if(count % 6 == 0) printf("\n");//满六个换一行
else printf(" ");
}
}
}
}
}