Java:杨辉三角

键盘录入数字n,输出n行杨辉三角(Java)


前言

        编写杨辉三角的程序会用到金字塔输出的知识点,点下面连接查看。输入一个整数n,控制台输出n行“*”金字塔的形状(Java)_不爱健身的数学子弟不是好程序员的博客-CSDN博客


一、杨辉三角是什么?

杨辉三角,是二项式系数在三角形中的一种几何排列。在欧洲,这个表叫做帕斯卡三角形帕斯卡(1623----1662)是在1654年发现这一规律的,比杨辉要迟393年,比贾宪迟600年。杨辉三角是中国古代数学的杰出研究成果之一,它把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合。

二、代码拆分解释

Scanner 语句键盘录入数字

//键盘录入数字n
        Scanner sc = new Scanner(System.in);
        System.out.println("请您输入一个数字n");
        int n = sc.nextInt();

为二维数组赋值:在赋值中根据杨辉三角的规律可以总结出每一行数字的规律。

如图所示(右侧):i表示行   j表示列,每一行的一个元素和最后一列元素都是1,所以在给数组赋值的时候,需要判断 if (j == 0 || j == arr[i].length - 1),如何符合条件,就直接给数组赋值为1,else的情况就是除去第一列和最后一列的元素,按照总结的规律赋值arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1]

//二维数组的赋值:
        for (int i = 0; i < arr.length; i++) {      //遍历数组,给每一行开辟空间
            arr[i] = new int[i + 1];                //计算每行的空间;例如i=0时第一行的数组大小为1,所以第一行只有一个元素,后面以此类推
            for (int j = 0; j < arr[i].length; j++) {   //j控制列数
                if (j == 0 || j == arr[i].length - 1) { //因为杨辉三角每一行的第一个元素和最后一个元素都是1,所以判断如果j=0||j=arr[i].length是元素为1
                    arr[i][j] = 1;                      //给每一行的第一列和最后一列赋值为1
                } else {
                    arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];//当前元素的值为上一行相邻两个元素的和(如图所示)
                }
            }
        }

二维数组输出语句:

//遍历二维数组:
        for (int k = 0; k < arr.length; k++) {  //二位数组的遍历,控制行数
            for (int j = 1; j <= n - k; j++) {  //控制每行空格的循环
                System.out.print("  ");         //输出每行前面的空格用来调整结果,使结果呈现出三角形形状
            }
            for (int j = 0; j < arr[k].length; j++) {//控制列数,遍历二维数组
                System.out.print(arr[k][j] + "    ");
            }
            System.out.println();                   //输出每行元素完了之后,换行

 关于遍历二维数组的详细步骤请看二维数组的遍历(Java)_不爱健身的数学子弟不是好程序员的博客-CSDN博客

三、代码运行和结果

1.代码运行

代码如下(示例):

package Mar0313;

import java.util.Scanner;

public class Demo01 {
    public static void main(String[] args) {
        //键盘录入数字n
        Scanner sc = new Scanner(System.in);
        System.out.println("请您输入一个数字n");
        int n = sc.nextInt();
        int[][] arr = new int[n][];                 //定义一个行数为n,列数不确定的二维数组

        //二维数组的赋值:
        for (int i = 0; i < arr.length; i++) {      //遍历数组,给每一行开辟空间
            arr[i] = new int[i + 1];                //计算每行的空间;例如i=0时第一行的数组大小为1,所以第一行只有一个元素,后面以此类推
            for (int j = 0; j < arr[i].length; j++) {   //j控制列数
                if (j == 0 || j == arr[i].length - 1) { //因为杨辉三角每一行的第一个元素和最后一个元素都是1,所以判断如果j=0||j=arr[i].length是元素为1
                    arr[i][j] = 1;                      //给每一行的第一列和最后一列赋值为1
                } else {
                    arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];//当前元素的值为上一行相邻两个元素的和(如图所示)
                }
            }
        }

        //遍历二维数组:
        for (int k = 0; k < arr.length; k++) {  //二位数组的遍历,控制行数
            for (int j = 1; j <= n - k; j++) {  //控制每行空格的循环
                System.out.print("  ");         //输出每行前面的空格用来调整结果,使结果呈现出三角形形状
            }
            for (int j = 0; j < arr[k].length; j++) {//控制列数,遍历二维数组
                System.out.print(arr[k][j] + "    ");
            }
            System.out.println();                   //输出每行元素完了之后,换行
        }
    }
}

2.结果

请您输入一个数字n
10
                    1    
                  1    1    
                1    2    1    
              1    3    3    1    
            1    4    6    4    1    
          1    5    10    10    5    1    
        1    6    15    20    15    6    1    
      1    7    21    35    35    21    7    1    
    1    8    28    56    70    56    28    8    1    
  1    9    36    84    126    126    84    36    9    1    

Process finished with exit code 0

总结

        以上为杨辉三角的输出方式。

        注意:1.每个循环表达的意思。

                   2.掌握除去第一列和最后一列的数字关系(arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];)

                   3.输出的时候输出的空格用来调整形状(金字塔)

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值