codeup27002 填充上三角
时空限制 1000ms/128MB
题目描述
方阵的主对角线之上称为“上三角”。
请你设计一个用于填充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(3~20)
程序输出:方阵的上三角部分。
要求格式:每个数据宽度为4,右对齐。
输入
输出
样例输入
5
样例输出
1 2 3 4 5
12 13 14 6
11 15 7
10 8
9
代码
#include<iostream>
#include<iomanip>
using namespace std;
const int N = 25;
int a[N][N]={0};
int main(){
int n,x,y,k;
cin>>n;
a[x=1][y=1] = k = 1;
while (k<n*(n+1)/2){
while (y+1<=n && !a[x][y+1]) a[x][++y]=++k;
while (x+1<=n && !a[x+1][y-1]) a[++x][--y]=++k;
while (!a[x-1][y]) a[--x][y]=++k;
}
for (int i=1; i<=n; i++){
for (int j=1; j<=n-i+1; j++) cout<<setw(4)<<a[i][j];
cout<<endl;
}
return 0;
}