认识循环嵌套(二)
描述
打印如下格式图形:
输入两个整数m和n,然后按如下格式输出。
比如输入
5 7
输出
1 2 3 4 5 6 7
2 3 4 5 6 7 8
3 4 5 6 7 8 9
4 5 6 7 8 9 10
5 6 7 8 9 10 11
输入
输入一行两个整数m和n,表示m行n列
其中,m和n均小于1000
输出
输出有m行n列,图形样式见样例。每个数字的场宽为4
输入样例 1
10 12
输出样例 1
1 2 3 4 5 6 7 8 9 10 11 12 2 3 4 5 6 7 8 9 10 11 12 13 3 4 5 6 7 8 9 10 11 12 13 14 4 5 6 7 8 9 10 11 12 13 14 15 5 6 7 8 9 10 11 12 13 14 15 16 6 7 8 9 10 11 12 13 14 15 16 17 7 8 9 10 11 12 13 14 15 16 17 18 8 9 10 11 12 13 14 15 16 17 18 19 9 10 11 12 13 14 15 16 17 18 19 20 10 11 12 13 14 15 16 17 18 19 20 21
---------------------------------------------------------------------------------------------------------------------------------
思路:
分析一下,这道题的难点在于,怎么样才能输出一个像三角形的方阵,我们把每一行拆开来看,我们仔细观察:
第一行:从1输出到12
第二行:从2输出到13
第三行:从3输出到14
……
发现规律了吗?我们每一行输出的第一个数字要比上一行大一,输出的最后一个数字要比上一行大一,所以,我们可以来定义两个变量,叫 l 和 r ,用 l 来表示输出的第一个数字,用 r 代表最后一个数字,然后输出l到r中的所有数字
好,我们已经知道如何输出每一行了,就是这样:
for(int i=l;i<=r;i++){
cout<<setw(4)<<i;
}
l++;
r++;
cout<<endl;
可是我们要输出很多行,要怎么办?
我们可以在套一层循环:
for(int j=1;j<=m;j++){
for(int i=l;i<=r;i++){
cout<<setw(4)<<i;
}
l++;
r++;
cout<<endl;
}
可能有人不能理解,我解释一下:
在循环里面的代码,是输出每一行对吧?那我们在外面在套一层循环,这样就能输出很多行
---------------------------------------------------------------------------------------------------------------------------------
代码~:
#include<bits/stdc++.h>
using namespace std;
int main(){
long long m,r,l=1;
cin>>m>>r;
for(int j=1;j<=m;j++){
for(int i=l;i<=r;i++){
cout<<setw(4)<<i;
}
l++;
r++;
cout<<endl;
}
return 0;
}
加油!!!