求符合给定条件的整数集 (15 分)
给定不超过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
分析:本题主要运用循环来实现的,主要大家要理解这种解决的方法,我们在观察输出的序列的时候也能发现一定的规律,他是有一定的顺序。仔细观察你会发现是从小到大排列的。
java代码实现:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in=new Scanner(System.in);
int t= in.nextInt();
int count =0;
int sum=0;
for(int i=t;i<=t+3;i++){
for(int j=t;j<=t+3;j++){
for(int k=t;k<=t+3;k++){
if(i!=j&&i!=k&&j!=k) {
sum = i * 100 + j * 10 + k;
count++;
if (count % 6 == 0) {
System.out.println(sum);
} else
System.out.print(sum + " ");
}
}
}
}
}
}
C语言代码实现:
#include<stdio.h>
int main()
{
int a=0;
int sum=0;
int count=0;
int i=0,j=0,k=0;
scanf("%d",&a);
for(i=a;i<=a+3;i++){
for(j=a;j<=a+3;j++){
for(k=a;k<=a+3;k++){
if(i!=j&&j!=k&&i!=k){
sum=i*100+j*10+k;
count++;
if(count%6==0){
printf("%d\n",sum);
count=0;
}
else
printf("%d ",sum);
}
}
}
}
return 0;
}