Java二维数组绝妙练习题—杨辉三角

createh53个月前 (02-01)技术教程31

问题描述

杨辉三角形又称Pascal三角形,它的第i+1行是(a+b)i的展开式的系数。

它的一个重要性质是:三角形中的每个数字等于它两肩上的数字相加。

下面给出了杨辉三角形的前4行:

1

1 1

1 2 1  

1 3 3 1

给出n,输出它的前n行。

输入格式

输入包含一个数n。

输出格式

输出杨辉三角形的前n行。每一行从这一行的第一个数开始依次输出,中间使用一个空格分隔。请不要在前面输出多余的空格。

样例输入

4

样例输出

1
1 1
1 2 1
1 3 3 1

数据规模与约定

1 <= n <= 34。

=================================

解题思路:

①:读完题目,看到需要打印行列,果断使用二维数组,创建二维数组triangleArray。

②:我们可以发现规律,杨辉三角形的第一列和最后一列都是一,所以第一步就是把第一列和最后一列的数1打印出来。

③:第二个规律,第一、二行都是1可以用步骤②解决,从第三行开始发现,除去第一列和最后一列,中间的数triangleArray[n][n]等于triangleArray[n-1][n]+triangleArray[n-1][n-1],即等于次位置上方的数加上左前方的数。

④:第三个规律,第几行,就有几列,所以我们在输出时就不能输出二维数组中无用的数。


思路分析完毕,代码演示:


import java.util.Scanner;

public class YangHuiTriangle {


public static void main(String[] args) {

//创建一个扫描对象

Scanner sc = new Scanner(System.in);


//接收控制台输入的数,表示打印几行杨辉三角

int n = sc.nextInt();

//创建一个二维数组

int[][] triangleArray = new int[n][n];

//第1列和第n+1列的数为1

for(int i = 0; i < n; i++) {

triangleArray[i][0] = 1; //第一列为1

}

for(int j = 0; j < n; j++) {

triangleArray[j][j] = 1;

}


//完成中间的数的赋值

for(int i = 2; i < triangleArray.length; i++) {

for(int j = 1; j < triangleArray[i].length; j++) {

triangleArray[i][j] = triangleArray[i-1][j] + triangleArray[i-1][j-1];

}

}


//打印二维数组中不为0的数

for(int i = 0; i < triangleArray.length; i++) {

for(int j = 0; j < triangleArray[i].length; j++) {

if(triangleArray[i][j] != 0 ) {

System.out.print(triangleArray[i][j] + " "); //不换行

}

}

System.out.println(); //换行

}


sc.close();

}

}

================================

之后还会继续分享Java练习题和一些重难点,后期会录制视频讲解,初来乍到,关注一下吧

相关文章

java程序员必备的基础知识之数组的定义和使用

如果希望保存一组有相同类型的数据,可以使用数组。数组的定义和内存分配Java 中定义数组的语法有两种: type arrayName[]; type[] arrayName;type 为Java中的任...

算法:有序数组的平方(Java版)(java 有序数组)

有序数组的平方题目描述:给定一个按非递减顺序排序的整数数组 nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。示例:输入: nums = [-4,-1,0,3,10] 输出: [0,1...

java数组的初始化及遍历(java数组元素初始化)

/*** 测试数组的三种初始化 以及遍历的两种方式* 静态初始化 动态初始化 默认初始化*/public class Test3 { private int id; private int age;...

小菜鸟学Java--如何拿下数组(java数组截取到新数组)

前面谈及到了引用数据类型,数组就是一种,它还是比较重要的一种,本篇就来详细说说它和向量。数组先来说说数组。那么什么是数组呢?它是在数组的基础上的。数组是一种常用的引用数据类型,相同数据类型的元素按照一...

刷题力扣349-两个数组的交集(两个数组的交集 ii)

这道题代码随想录用的是哈希数据结构,什么时候用哈希表,哈希表都是用来快速判断一个元素是否出现在集合里,相对于枚举的话,哈希表的时间复杂度只有O(1)。常见的三种哈希结构数组set(集合)map(映射)...

Java使用输出流OutputStream导出Excel遇到的问题及解决方法

这半年一直在参与一个新系统的软件开发,再此期间遇到了一个小小的问题,就是使用原生POI导出Excel时,会生成非Excel格式的文件,而且文件名称也不是设置好的,而是导出的方法名,如下图;不过这种文件...