题目:
请你设计一个用于填充n阶方阵的上三角区域的程序。填充的规则是:使用1,2,3….的自然数列,从左上角开始,按照顺时针方向螺旋填充。
例如:当n=3时,输出:
1 2 3
6 4
5
当n=4时,输出:
1 2 3 4
9 10 5
8 6
7
当n=5时,输出:
1 2 3 4 5
12 13 14 6
11 15 7
10 8
9
要求:
程序运行时,要求用户输入整数n(3~20)
程序输出:方阵的上三角部分。
要求格式:每个数据宽度为4,右对齐。
解题思路:
1、先水平向右打印值,列坐标c遇到边界 b 结束;(下图红色线对应的值)
2、再由右上向左下打印斜对角线位置的值,行坐标 r 遇到边界 b 结束;(下图绿色线对应的值)
3、最后由下往上打印值,行坐标 r 遇到 i 结束打印;(下图蓝色线对应的值)
4、重复1-3
5、当 i 等于 b,打印最后一个数值,结束;(红色圈圈对应的值)
以n = 10为例:
#include <iostream>
void SpiralTriangle()
{
int n = -1;
while (std::cin >> n)