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

createh54个月前 (02-01)技术教程64

问题描述

杨辉三角形又称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中的任...

DJL 之 Java 玩转多维数组,就像 NumPy 一样

本文适合有 Java 基础的人群作者:DJL-LankingHelloGitHub 推出的《讲解开源项目》系列。有幸邀请到了亚马逊 + Apache 的工程师:Lanking( https://git...

Java数组详解(java数组操作方法)

数组,也叫Array,是由同一种数据类型按照一定的顺序排列的集合,给这个数组起一个名字。是一种数据类型。定义数组,在类型的后面加一个[]定义数组有两种方式①静态初始化 int[] num=new in...

讲解C#中多维数组的长度和范围的特性和使用方法

在 C# 中,多维数组是一种可以包含多个维度(通常是二维或三维)的数组类型。理解其长度和范围的特性有助于正确使用和避免错误。以下是多维数组的长度、范围特性及其使用方法的详细讲解。1. 多维数组的定义和...

100个Java工具类之77:数组操作的可靠助手ArrayUtils和Arrays

众所周知,数组操作是比较复杂的,而ArrayUtils就是为了为简化数组操作而生的,它在数组查找、排序、合并等方面提供了多种方法,合理使用,可以让代码看起来更简洁易用,下面通过几个实例来对其进行介绍。...

Java 18 正式发布:附带简易 HTTP 服务器,弃用 Finalization

甲骨文(Oracle)发布了 Java 编程语言和虚拟机的第 18 版。该版本的最终特性主要集中在以下 9 个 JEP 上:JEP 400:默认字符集为UTF-8JEP 408:简易Web服务器JEP...