题目描述
蛇形矩阵是由1开始的自然数依次排列成的一个矩阵上三角形。
输入
本题有多组数据,每组数据由一个正整数N组成。(N不大于100)
输出
对于每一组数据,输出一个N行的蛇形矩阵。两组输出之间不要额外的空行。矩阵三角中同一行的数字用一个空格分开。行尾不要多余的空格。
样例输入
5
样例输出
1 3 6 10 15
2 5 9 14
4 8 13
7 12
11
思路:观察横纵坐标的变化情况,找规律就可以了。
代码如下:
#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int maxx=1e2+10;
int a[maxx][maxx];
int n;
int main()
{
scanf("%d",&n);
int cnt=1,num=(1+n)*n/2;
int sx=1,sy=1;
while(num--)
{
a[sx][sy]=cnt++;
if(sx-1>0) sx-=1,sy+=1;
else sx=sy+1,sy=1;
}
for(int i=1;i<=n;i++)
for(int j=1;j<=n-i+1;j++) printf("%d%c",a[i][j],j==n-i+1?'\n':' ');
return 0;
}
努力加油a啊,(o)/~