7-19 求符合给定条件的整数集
分数 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
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
代码
#include<stdio.h>
int main()
{
int a,b,i,j,k,flag=0,sum;
scanf("%d",&a);
b=a+4;
for(i=a;i<b;i++)
{
for(j=a;j<b;j++)
{
for(k=a;k<b;k++)
{
if(i!=j && j!=k && k!=i)
{
flag++;
sum=100*i+10*j+k;
if(flag%6!=0)
{
printf("%d ",sum);
}
else
{
printf("%d\n",sum);
}
}
}
}
}
return 0;
}
注意事项:
1、注意如何按顺序排列三位数的大小——>得出需要通过三次for循环的嵌套进行完成
2、注意循环的嵌套关系,需要在i,j,k分别不相等时完成后续的flag计数以及输出判断
3、注意如何每六个一换行——>得出需要额外设定flag进行计数,并通过取余进行筛选,得到判断条件,每次取余的时候进行换行处理。