杨辉三角形(Java版)

article/2025/10/13 14:00:16

不为失败找理由,只为成功找方法。所有的不甘,因为还心存梦想,所以在你放弃之前,好好拼一把,只怕心老,不怕路长。

文章目录

  • 1. 什么是杨辉三角形
  • 2. 实现思路(方式)
    • 2.1 递归方式
    • 2.2 递归+数组方式
  • 代码编写
  • 总结


1. 什么是杨辉三角形

    杨辉是一个人名,我国宋代数学家杨辉在其著作《详解九章算法》中给出的一个用数字排列起来的三角形阵。由于杨辉在书中引用了贾宪著的《开方作法本源》和“增乘开方法”,因此这个三角形也称“贾宪三角”。它的规律我们先看如下图:
在这里插入图片描述
如上图所示,分析的很清楚了,其实仔细思考一下就很容易看出这和数学中的二项式是有很大的联系的,即(a+b)^n的展开式中的各项系数依次对应杨辉三角的第(n+1)行中的每一项。


2. 实现思路(方式)

     杨辉三角的实现有很多种,而本篇文章只介绍两种,一种是非常常见,也是比较简单实现的递归方式,另一种是在递归的基础上加上数组的存储功能实现。接下来我们一一刨析。

2.1 递归方式

    在说思路之前,我们先得理解什么是递归。递归简单的理解方式就是在一个方法中满足一定条件的时候不断调用自身。现在已经理解了什么是递归,那么满足杨辉三角的条件是什么呢?我们看如下图:
在这里插入图片描述
由上图所示,把杨辉三角看出行和列,然后再进行分析。我们由图可以看出每一行的第1列和最后1列都是数字1,然后其余的都是从当前数的上一行左右两边相加得到的数字。比如第三行第二列的2,就是上一行得到左右两边相加(1+1)得到的。根据这个规律,就可以得出一条递归公式,我们把行用字母a表示,列用字母b表示,最终得出的公式为:s(a,b)=s(a-1,b-1) + s(a-1,b),根据这个公式就可以得到当前a行b列的数字。

2.2 递归+数组方式

    根据刚刚的分析,我们已经知道了什么是递归和本篇文章的杨辉三角的递归公式。那么递归+数组的方式就是在递归的基础上加上数组。而我们知道数组是可以存储数据的,那么我们可以利用这个特性把递归出来的每一个数字存到数组中,由此实现了递归+数组的方式。

代码编写

    经过上述的详情介绍,接下来就是代码实现了。不过在实现代码之前,我们来一个需求,把前面两种方式合并成为一个需求,这种方式实现杨辉三角,我觉得会更有意思。那么我们先看需求:定义一个类,在类中声明两个成员变量总行数和存储杨辉三角每个数字的二维数组,最后定义两个方法,第一个为使用递归获得杨辉三角,第二个为实现存储杨辉三角。这个需求已经介绍的很清晰了,那么废话不多说,直接上代码。

import java.util.Scanner;/*** 使用递归实现杨辉三角形并把每一行的数据存储到数组中*/
public class YangHui {private int n; //总行数private int[][] array; //存储前n行杨辉三角形的二维数组/*** 构造方法*/public YangHui(){}public YangHui(int n, int[][] array) {this.n = n;this.array = array;}/*** 使用递归实现杨辉三角形* @param a 行* @param b 列* @return*/public int iter(int a, int b){if (b == 1 || b == a){return 1;}else {return iter(a-1,b-1) + iter(a-1,b);}}/*** 利用数组把杨辉三角形的数据存储到数组中,并打印*/public void printNum() {for (int i = 0; i < this.array.length; i++) { //行for (int j = 0; j <= i; j++) { //列//调用迭代方法存储到数组中array[i][j] = iter(i + 1, j + 1);//打印System.out.print(array[i][j] + "\t");}System.out.println();}}/*** 主程序入口* @param args*/public static void main(String[] args) {//1.使用扫描仪Scanner sc = new Scanner(System.in);System.out.print("请输入行数:");int row = sc.nextInt();//2.创建实例 并使用构造方法设置对象属性YangHui yangHui = new YangHui(row,new int[row][row]);//4.调用方法打印杨辉三角形yangHui.printNum();}
}

运行结果如图所示:
在这里插入图片描述


总结

以上就是使用java实现的杨辉三角形,实现的是直角形的杨辉三角,如果想实现等腰形的杨辉三角,可以在存储杨辉三角并打印的printNum方法里进行自行修改。本篇的内容就到此结束了,如果该篇内容觉得对你有所帮助,请留下您的足迹。最后如果上述有所出入,欢迎道友畅聊相关技术。


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

相关文章

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

一、前言 既然是实现杨辉三角&#xff0c;就要知道什么是杨辉三角。如下图&#xff0c;就是两种杨辉三角。 &#xff08;1&#xff09;等边形状的杨辉三角 &#xff08;2&#xff09;直角形状的杨辉三角 在知道这两种都是杨辉三角之后&#xff0c;我们就来实现利用java语言打…

杨辉三角(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;好家伙这玩意给我报错把我搞懵…