博主不定期更新【保研/推免、C/C++、5G移动通信、Linux、生活随笔】系列文章,喜欢的朋友【点赞+关注】支持一下吧!
给定不超过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
一开始没想到好的解法,使用了傻瓜解法:
#include <>
int main()
{
int A;
scanf("%d", &A);
int a=A;
int b=A+1;
int c=A+2;
int d=A+3;
printf("%d%d%d %d%d%d %d%d%d %d%d%d %d%d%d %d%d%d\n",a,b,c,a,b,d,a,c,b,a,c,d,a,d,b,a,d,c);
printf("%d%d%d %d%d%d %d%d%d %d%d%d %d%d%d %d%d%d\n",b,a,c,b,a,d,b,c,a,b,c,d,b,d,a,b,d,c);
printf("%d%d%d %d%d%d %d%d%d %d%d%d %d%d%d %d%d%d\n",c,a,b,c,a,d,c,b,a,c,b,d,c,d,a,c,d,b);
printf("%d%d%d %d%d%d %d%d%d %d%d%d %d%d%d %d%d%d\n",d,a,b,d,a,c,d,b,a,d,b,c,d,c,a,d,c,b);
return 0;
}
正常解法:
#include <>
int main()
{
int a,i,j,k;
scanf("%d", &a);
int cnt = 0;
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)
{
printf("%d", 100*i+10*j+k);
//由于这里不涉及0,因此也可以printf("%d%d%d", i, j, k);
cnt++;
if (cnt%6 == 0)
{
printf("\n");
}
else
{
printf(" ");
}
}
}
}
}
return 0;
}