使用java代码来打印杨辉三角形图案

package yanghuisanjiaoxing;

import java.util.Scanner;

/*

 * 使用二维数组打印杨辉三角形的图案

 * 

 * 1

 * 1 2 1

 * 1 3 3 1

 * 1 4 6 4 1

 * 1 5 10 10 5 1

 * 

 * 分析:看这种图像的规律

 A:任何一行的第一列和最后一列都是1

 B:从第三行开始,每一个数据是它上一行的前一列和它上一行的本列之和。

 步骤:

 A:首先定义一个二维数组。行数如果是n,我们把列数也先定义为n。

 这个n的数据来自于键盘录入。

 B:给这个二维数组任何一行的第一列和最后一列赋值为1

 C:按照规律给其他元素赋值

 从第三行开始,每一个数据是它上一行的前一列和它上一行的本列之和。

 D:遍历这个二维数组。

 */

public class YangHuiSanJiaoXingDemo {

// 打印二维数组的方法:

public static void printArray2(int[][] arr) {

for (int x = 0; x < arr.length; x++) {

for (int y = 0; y <= x; y++) {

System.out.print(arr[x][y] + “\t”);

}

System.out.println();

}

}

//打印一般的二维数组的方法

public static void print2(int[][] arr2) {

for (int x = 0; x < arr2.length; x++) {

for (int y = 0; y < arr2[x].length; y++) {

System.out.print(arr2[x][y] + “, “);

}

}

}

public static void main(String[] args) {

int[][] arr2 = { { 12, 13, 22, 33 }, { 11, 22, 33 }, { 55, 66, 77 } };

print2(arr2);

System.out.println(“—————“);

Scanner input = new Scanner(System.in);

System.out.println(“请输入一个数字:”);

int n = input.nextInt();

// 定义一个二维数组,行数如果为n,我们把列也定义为n

int[][] arr = new int[n][n];

// 给这个二维数组任何一行的第一列和最后一列赋值为1

for (int x = 0; x < arr.length; x++) {

arr[x][0] = 1;

arr[x][x] = 1;

}

/*

* 按照规律给其他元素赋值 从第三行开始,每一个数据是它上一行的前一列和它上一行的本列之和。

* 1 

* 1 1

* 1 2 1 

* 1 3 3 1 

* 1 4 6 4 1 

* 1 5 10 10 5 1

*/

for (int x = 2; x < arr.length; x++) {

for (int y = 1; y < x; y++) {

arr[x][y] = arr[x – 1][y – 1] + arr[x – 1][y];

}

}

printArray2(arr);

}

}

    原文作者:杨辉三角问题
    原文地址: https://blog.csdn.net/zhongxu_yuan/article/details/52239846
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞