题目描述
蛇形矩阵是由1开始的自然数依次排列成的一个矩阵上三角形。
输入
本题有多组数据,每组数据由一个正整数N组成。(N不大于100)
输出
对于每一组数据,输出一个N行的蛇形矩阵。两组输出之间不要额外的空行。矩阵三角中同一行的数字用一个空格分开。行尾不要多余的空格。
样例输入
5
样例输出
1 3 6 10 15
2 5 9 14
4 8 13
7 12
11
分析:
以样例来分析,我们可以得到下面几个步骤:
n=5;
第0行: 1 (0,0)
第1行: 2(1,0) 3 (0,1)
第2行: 4(2.0) 4(1.1) 6(0,2)
第4行: 7(3,0) 8(2,1) 9(1,2) 10(0,3)
第5行: 11(4,0) 12 (3,1) 13(2,2) 14(1,3) 15(0,4)
通过以上我们可以得出以下结论:
1.第i行有i+1个数字
2.每一行的数组下标走向都是行–,列++。当行等于0和列等于行数时,本行的循环结束。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input=new Scanner(System.in);
int n=input.nextInt();
int num=1;
int[][] a=new int[n][n];
for(int i=0;i<n;i++)
{
int k=0;
for(int j=i;j>=0;j--,k++)
{
a[j][k]=num;
num++;
}
}
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
if(a[i][j]==0)
System.out.print(" ");
else
System.out.print(a[i][j]+" ");
}
System.out.println();
}
}
}