JAVA实现杨辉三角的三种方式

article/2025/10/13 14:03:31

一、前言

既然是实现杨辉三角,就要知道什么是杨辉三角。如下图,就是两种杨辉三角。

(1)等边形状的杨辉三角

 

(2)直角形状的杨辉三角

 

在知道这两种都是杨辉三角之后,我们就来实现利用java语言打印出杨辉三角。

二、杨辉三角的规律

  1. n行有n个数字.
  2. 每一行的开始和结尾数字都为1.

用二维数组表示就是a[i][0]=1;  a[i][j]=1(i==j)

  1. n+1行的第i个数字等于第n行的i-1个数字加上第n行的i个数字。

用二维数组表示就是 a[i+1][j]=a[i][j-1]+a[i][j];

三、代码部分

3.1、创建一个长度为10,宽度为10的二维数组,但赋值和输出时只输出杨辉三角那个范围的数

首先,我们得理解定义一个长度和高度都为10的二维数组时,他到底做了什么。

public class Test {public static void main(String[] args) {int [][] arr=new int [10][10];for(int i=0;i<arr.length;i++) {for(int j=0;j<arr[i].length;j++) {System.out.print(arr[i][j]+"\t");}System.out.println();}}
}

输出图:

数组的图为可以看出,实际是给每个位置上都赋值为0;

而我们要做的是给A部分的位置赋值并且输出,而B部分的位置不用管。

A部分与B部分的区别在于:A部分的横坐标大于等于纵坐标。用数组中的话就是i<=j;知道要赋值的范围,那么for循环的语句就知道了啦,就为

for(int i=0;i<arr.length; i++) {for(int j=0;j<=i;j++) {}
}

第一种该方法完整代码:

public class YHSJ {public static void main(String[] args) {//定义了一个长度为10,高度为10的二维数组,数组中的值都为0;int[][] arr=new int[10][10];for(int i=0;i<arr.length; i++) {//由于只是给杨辉三角内的位置赋值,所以是j<=ifor(int j=0;j<=i;j++) {//根据规律,使用if else 赋值if(j==0||j==i) {arr[i][j]=1;}else {arr[i][j]=arr[i-1][j-1]+arr[i-1][j];}/*由于只是输出杨辉三角范围内的值,所以在内层循环就输出,这种方法不能全部赋值完之后再输出"\t"的原因是10和小于10的数组的宽度不同,所以使用\t制表符能使数与数之间距离相等*/System.out.print(arr[i][j]+"\t");}System.out.println();}}
}

对应效果图:

3.2、直接创建一个和杨辉三角形状一样的数组再赋值输出

    在前面我们使用了一个长10高10的数组,但是最后我们只用了它的A部分,思考一下,为什么我们不直接创建一个和前面那个A部分形状一样的数组呢?

   形状如下图:

    知道基本的概念之后,我们先创建该数组,首先可以确定的是这里的高度还是为10,也就是横坐标最大还是为10,但是纵坐标就是小于等于该行的横坐标。

int[][] arr=new int[10][];for(int i=0;i<arr.length;i++) {arr[i]=new int[i+1];}

    在数组创建好之后,再就是赋值了,之前赋值用的是j<=i,但是此处数组的范围就是杨辉三角的范围,所以可以直接对数组进行内外两层循环。

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

    而赋值的代码也是一样,不过这种方法就可以赋值完再输出,不用像第一种一样赋值时输出。

第二种方法完整代码:

public class YHSJ_2 {public static void main(String[] args) {int[][] arr=new int[10][];for(int i=0;i<arr.length;i++) {arr[i]=new int[i+1];}for(int i=0;i<arr.length;i++) {for(int j=0;j<arr[i].length;j++) {if(j==0 || i==j) {arr[i][j]=1;}else {arr[i][j]=arr[i-1][j]+arr[i-1][j-1];}}}for(int i=0;i<arr.length;i++) {for(int j=0;j<arr[i].length;j++) {System.out.print(arr[i][j]+"\t");}System.out.println();}}
}

    第二种补充说明:这里用这种是输出的一个直角三角形,但是在最后输出的时候加上一段就可以变成等腰三角形了;(但是由于制表符的问题,还是有一些不规范,觉得不好参考第三种

public class YHSJ_2 {public static void main(String[] args) {int[][] arr=new int[10][];for(int i=0;i<arr.length;i++) {arr[i]=new int[i+1];}for(int i=0;i<arr.length;i++) {for(int j=0;j<arr[i].length;j++) {if(j==0 || i==j) {arr[i][j]=1;}else {arr[i][j]=arr[i-1][j]+aarr[i-1][j-1];}}}for(int i=0;i<arr.length;i++) {int num=(arr.length-i)/2;for(int k=0;k<=num;k++) {System.out.print("\t");}for(int j=0;j<arr[i].length;j++) {System.out.print(arr[i][j]+"\t");}System.out.println();}}
}

3.3、接下来为大家介绍一种等边三角形输出的简单方法

参考文章链接:http://www.cnblogs.com/JumperMan/p/6759422.html

代码:

public class YHSJ_1 {public static void main(String[] args) {int rows = 10;for (int i = 0; i < rows; i++) {int number = 1;// 打印空格字符串System.out.format("%" + (rows - i) * 2 + "s", "");for (int j = 0; j <= i; j++) {System.out.format("%4d", number);number = number * (i - j) / (j + 1);}System.out.println();}}
}

  重点在于那个number=number*(i-j)/(j+1),掌握了杨辉三角的作用。而关于System.out.format是一种类似于C语言中的输出,查看API即可知。

效果图:

 


http://chatgpt.dhexx.cn/article/WXr7g93F.shtml

相关文章

杨辉三角(Java)

实现思路&#xff1a;我们可以先把杨辉三角想象成一个空的二维数组&#xff0c;然后再给它赋值输出即可。 关键在于如何赋值&#xff1a;仔细观察上图可以得出除了每一行第一个数以及最后一个数&#xff08;都是1&#xff09;&#xff0c; 中间的数字规律就是&#xff1a;a[ i …

Java:杨辉三角

键盘录入数字n&#xff0c;输出n行杨辉三角&#xff08;Java&#xff09; 文章目录 前言一、杨辉三角是什么&#xff1f;二、代码拆分解释三、代码运行和结果 1.代码运行2.结果 前言 编写杨辉三角的程序会用到金字塔输出的知识点&#xff0c;点下面连接查看。输入一个整数n&…

Java语言实现杨辉三角

一.提出问题。 使用二维数组打印出如下图的杨辉三角。 二.分析问题。 1.首先想要输出杨辉三角&#xff0c;就要找到它有什么规律&#xff1f; ①第n行有n个数字&#xff1b; ②每一行开始和结束的数字都为1&#xff1b; ③每一个数字都等于它的左上角的数字与右上角数字之和。…

java实现杨辉三角

首先杨辉三角的构成如下 通过分析能得出如下两个规律 1.第n行有n个元素&#xff0c;并且每一行的首尾元素都是1 1.中间的元素等于上面相邻的元素之和&#xff0c;用二维数组表示就是arr[i][j] arr[i-1][j] arr[i-1][j-1] 接下来就是实现动态开辟二维数组以此表示杨辉三角形…

Java编写杨辉三角

如图就是一个7层的杨辉三角&#xff0c;今天我们就用Java来编写这样一个杨辉三角。我还是把这个过程分为几个小的步骤来完成。 一、编写一个二维数组 通过观察&#xff0c;我们可以知道这样一个杨辉三角其实就是每行列数不同的二维数组&#xff0c;且第i行的列数其实就是i&am…

不到50天 零基础 如何学习【数据结构】?

转载于知乎 点击原文链接&#xff0c;可进入原问题 考研计算机&#xff0c;还剩50天&#xff0c;目前零基础&#xff0c;如何学习数据结构&#xff1f; 题主情况&#xff1a; 1.零基础跨专业考研计算机&#xff0c;目前数学英语进度不错。但专业课…因为c语言也是零基础&#x…

自学 数据结构(一)

数据结构的简介 前言数据结构起源一、逻辑结构二、物理结构三、总结概念 前言 数据结构分别有两个重要结构&#xff1a;逻辑结构和物理结构 数据结构起源 数据结构是一门研究非数值计算的程序设计问题中的操作对象&#xff0c;以及官们之间的关系和操作等相关 问题的学科。 …

数据结构基础入门

简单地说&#xff0c;数据结构是以某种特定的布局方式存储数据的容器。这种“布局方式”决定了数据结构对于某些操作是高效的&#xff0c;而对于其他操作则是低效的。首先我们需要理解各种数据结构&#xff0c;才能在处理实际问题时选取最合适的数据结构。 首先列出一些最常见…

自从上了数据结构课之后就想自学c++了

所以今天是摆烂的第三天&#xff1a; 就是来总结一下自己刚学c常犯的小错误&#xff08;在注释里&#xff09;和总结吧&#xff1b; 先来看看hello world输出代码&#xff1b; //打了四遍这个代码终于对了TAT //在一整个程序里面如果有多个文件并且不止一个main函数的话&…

如何学好数据结构?

大家好&#xff0c;我是程序员吴师兄。 最近在公众号发布了不少图解 LeetCode 的文章&#xff0c;一些同学在后台打卡&#xff0c;甚是感动&#xff0c;以后也会每天都发布一篇&#xff0c;希望能帮助大家更好的刷题&#xff0c;通过算法面试&#xff0c;进入心仪的大厂。 谈到…

为什么要学数据结构?

文章目录 一、前言二、为什么要学数据结构三、数据结构无处不在3.1 数据库3.2 操作系统3.3 文件压缩3.4 游戏 四、数据结构类型 一、前言 在可视化化程序设计的今天&#xff0c;借助于集成开发环境可以很快地生成程序&#xff0c;程序设计不再是计算机专业人员的专利。很多人认…

如何学习数据结构与算法

经过一段时间的数据结构与算法的学习&#xff0c;和学习了前人的经验&#xff0c;为了更好的指导自己&#xff08;希望也能帮助到别人&#xff09;之后数据结构与算法的学习&#xff0c;总结一下数据结构与算法学习的方法。 一、记住数据结构&#xff0c;记住算法思想&#xf…

怎样学好数据结构

1、数据结构学习思路 &#xff08;1&#xff09;数据结构是计算机专业最重要最基础的一门课&#xff0c;对于有过编程经验的人&#xff0c;结合自己的编程体会去领悟它的思想&#xff1b;对于初学者&#xff0c;选择一种自己最熟悉的语言去分析它。而且&#xff0c;随着编程经…

如何自学《数据结构与算法》?

众所周知&#xff0c;《数据结构与算法》是程序员面试中的重中之重&#xff0c;也是编程中非常重要的组成部分&#xff0c;然而非科班出身的人&#xff0c;学起来有一个相当长的探索期。下面我整理了一个数据结构与算法的思维导图&#xff0c;供大家参考。 1.总览 2.学习方法 …

入门篇|学渣是如何自学数据结构的?

作者 | 小鹿 来源 | 一个不甘平凡的码农 写在前边 ------------------------------------------- 今日明哥推荐一篇文章&#xff0c;小鹿是个勤快并且认知定位非常清晰&#xff0c;有极强的执行能力的小伙子。作为一个大学生&#xff0c;这个就很流弊了。有时候不是你多牛&am…

MATLAB的.fig文件打不开——有效解决

如果没有报错的话&#xff0c;那么可能是显示关了。报错可能是保存方式不对。可以看下面例子。 文章目录 没报错但打不开报错 没报错但打不开 示例正弦函数图像。 x -pi:pi; y sin(x);显示功能关闭打不开。 figure(visible,off); plot(x,y) savefig(1.fig);下面打得开 f…

matlab命令打开Word文档

本博文源于Matlab骚操作系列&#xff0c;旨在讲述文档打开操作。首先要保证自己有Word。然后我们开始实验。 实验步骤 创建Word服务器设置Word服务器可见新建空白文档写入文档内容保存文档 实验内容 创建word服务器 >> try Word actxGetRunningServer(Word.Applicat…

MATLAB无法直接打开M文件

MATLAB无法直接打开M文件 啊这1. 下载MATLAB文件关联&快捷修复文件2. 在MATLAB添加路径3. 运行associateFiles.m4. 打开生成的注册表文件5. 重启电脑 啊这 穷折腾装了个2020试试&#xff0c;发现安装后没有关联M文件。 添加打开方式为MATLAB&#xff0c;打开M文件只能启动…

matlab无法打开excel的问题

matlab无法打开excel problem怎么解决 problem 重装系统时直接移植了matlab和office两个大套件&#xff0c;之前用matlab调用读取电子表格一直没有什么问题&#xff0c;今天在统计手机上网流量的时候想用matlab对表格里的单位处理一下&#xff0c;好家伙这玩意给我报错把我搞懵…

Matlab突然打不开,运行后一闪就消失了,任务管理器也没有的解决办法

记录一下平时遇到的一些bug Matlab官方issue 参考官网链接有3种可能导致标题现象 一种一种试一下&#xff0c;包括删掉Appdata文件夹的Matlab r2020a文件夹(对我的计算机无效) 最后我的计算机试到第三种就可以了 在桌面启动程序属性里目标路径后加 -nodesktop 再双击运行就…