循环实现图案输出
一、X形图案
1.代码
#include<iostream>
using namespace std;
int main()
{
int n = 0, i = 0, j = 0;
while (cin >> n)
{
for (i = 0; i < n; ++i)
{
for (j = 0; j < n; ++j)
{
if (i == j || j == n - i - 1)
cout << "*";
else
cout << " ";
}
cout << endl;
}
}
return 0;
}
2.代码运行结果
3.实现原理
- 以输入数为5作为例子,将该图形转换为表格
0 | 1 | 2 | 3 | 4 | |
---|---|---|---|---|---|
0 | * | * | |||
1 | * | * | |||
2 | * | ||||
3 | * | * | |||
4 | * | * |
- 可以把该图看成是一个二维数组列表。
- 由图可得,当行标与列标相等时输出为* 号,当列标为n减去行标的结果时,输出也为*号,而其他情况输出空格。
- 外层套上while循环,实现多组输入。
二、箭形图案
1.代码
#include<iostream>
using namespace std;
int main()
{
int n = 0, i = 0, j = 0;
while (cin >> n)
{
for (i = 0; i < n + 1; ++i)
{
for (j = 0; j < 2 * n - 2 * i; ++j)
cout << " ";
for (j = 0; j < i + 1; ++j)
cout << "*";
cout << endl;
}
for (i = 0; i < n; ++i)
{
for (j = 0; j < 2 * (i + 1); ++j)
cout << " ";
for (j = 0; j < n - i; ++j)
cout << "*";
cout << endl;
}
}
return 0;
}
2.代码运行结果
3.实现原理
- 以最长一行作为分界,上下两边都是n行,则以最长一行及其上面的输出(简称上式)做为一次循环实现,以最长一行以下的输出(简称下式)作为一次实现。
- 通过运行结果,可以看出,上式的空格数量以2的倍数递减,而 * 号数量则从1递增;下式的空格数量以2的倍数递增,而 * 号数量则从n+1递减。
- 令上式循环n+1次,输出空格的循环循环2 * n - 2 * i次,然后再进行i + 1次循环输出 * 号,每一行内容输出结束后进行换行,进而上式的代码完成。
- 接着下式的代码因最长一行已在上式输出,所以下式只需进行n次循环;i从0开始,则输出空格的循环循环 2 * (i + 1) 次;因为下式 * 号数量从n递减,所以输出*号的循环进行n - i次;每一行内容输出结束后进行换行,进而下式的代码完成。
需要注意的是下式的空格是以2的倍数递增下去的,不能以2作为判断而将条件设置为n+2*i
三、直角三角形图案
1.代码
#include<iostream>
using namespace std;
int main()
{
int n = 0, i = 0, j = 0;
while (cin >> n)
{
for (i = 0; i < n; ++i)
{
for (j = 0; j <= i; ++j)
cout << "*" << " ";
cout << endl;
}
}
return 0;
}
2.代码运行结果
- 通过运行结果,可以看出,*号数量从1开始递增,行数为n,通过两个循环就可实现。
四、翻转直角三角形图案
1.代码
#include<iostream>
using namespace std;
int main()
{
int n = 0, i = 0, j = 0;
while (cin >> n)
{
for (i = n; i > 0; --i)
{
for (j = 0; j < i; ++j)
cout << "*" << " ";
cout << endl;
}
}
return 0;
}
2.代码运行结果
- 与上一题类似,只需将i循环n次,并且把i初始化为n,使j循环实现*号数量从n递减。