问题描述:
给定不超过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
没有错误代码,因为我太菜了根本不会…
问题分析:
- 考虑到二重循环,但思路一直是用循环先表示一行再集体表示。
- 没能想到用循环变量i、j、k解决问题
正确代码
#include <iostream>
using namespace std;
int main()
{
int A;
cin>>A;
int count = 0;
for(int i=A;i<A+4;i++)
{
for(int j=A;j<A+4;j++)
{
for(int k=A;k<A+4;k++)
{
if(i!=j&&j!=k&&k!=i)
{
count++;
if(count%6==0)
{
cout<<i*100+j*10+k<<endl;
}
else{
cout<<i*100+j*10+k<<" ";
}
}
}
}
}
}
代码分析
- 当k循环结束会再次j循环,j循环结束,会再次i循环 i是从小到大输出,会重新开启i j循环
- 里面的两重循环结束,一行也完成了输出
- 因为除去i的取值,j k可以取三个值,除去两两相同的取值,刚好剩下3*3-3=6个
- 由观察发现,十位在每行也是递增输出
- 个位每两个重新递增输出
总结
- 循环表示矩阵不止能表示行列数,还能表示里面的数字!