【Java题解】杨辉三角—力扣

news2025/1/9 7:01:16

 🎉欢迎大家收看,请多多支持🌹

🥰关注小哇,和我一起成长🚀个人主页🚀

⭐目前主更 专栏Java ⭐数据结构

⭐已更专栏有C语言、计算机网络⭐


题目链接:杨辉三角

目录👑

⭐题目描述:​

🌙大体分析: 

🔆题目代码及详解


⭐题目描述:

🌙大体分析: 

 我们可以看到题中要求我们用列表来写这个题,

List<List<Integer>>是一个嵌套列表,列表里面存放的也是列表,且存放的列表里面存放的是Integer类型的对象。这类似与一个二维数组。

所以我们可以先创建一个嵌套列表对象,由于第一行始终只有一个数字1,我们可以先添加进去:

       List<List<Integer>> list = new ArrayList<>();
       List<Integer> list1 = new ArrayList<>();
       list1.add(1);
       list.add(list1);

现在画图来分析一下

 我们可以看到每一行的首位数字都是1,而这之间的数字都是由上一行的同列数字加上前一个数字。

比如,图中红色的3由上一行同列的2和2的前一个数字1相加得来。

因此我们可以利用循环来将每一行中间的数字用上面的方法算出来,我们要注意,是只有每一行除了首尾的数字才这样计算,所以注意循环的判断条件和初始值。

           for(int i = 1; i < numRows;i++){
           //每一行的开始
           List<Integer> temp = new ArrayList<>();
           temp.add(1);
           //每一行中间
           List<Integer> prerow = list.get(i-1);//当前行的前一行
           for(int j = 1; j < i; j++){
               int val1 = prerow.get(j);
               int val2 = prerow.get(j - 1);
               int value = val1 + val2;
               temp.add(value);
           }
           //每一行末尾
           temp.add(1);
           list.add(temp);
       }

每一行先创建一个列表对象,先将1添加进去,然后循环添加中间数字,再添加末尾的1。

每一行列表的数字添加好后,记得还要将这个列表添加进外层列表。

🔆题目代码及详解

该题总的代码:

class Solution {
    public List<List<Integer>> generate(int numRows) {
       List<List<Integer>> list = new ArrayList<>();
        if(numRows <= 0){
            return list;
        }
       List<Integer> list1 = new ArrayList<>();
       list1.add(1);
       list.add(list1);
       for(int i = 1; i < numRows; i++){
        //每一行的开始
        List<Integer> temp = new ArrayList<>();
        temp.add(1);
        //每一行中间
        List<Integer> preRow = list.get(i-1);//当前行的上一行
        for(int j = 1; j < i; j++){
            int val1 = preRow.get(j);
            int val2 = preRow.get(j - 1);
            int value = val1 + val2;
            temp.add(value);
        }
        //每一行的末尾
        temp.add(1);
        list.add(temp);
       }
        return list;
    }
}

 首先,我们创建了一个List<List<Integer>>类型的list来存储整个杨辉三角。然后,我们检查numRows是否小于或等于0,如果是,则直接返回一个空的list。

杨辉三角的第一行总是只有一个1,我们将其作为一个List<Integer>添加到list列表中。

从第二行开始,我们逐行生成杨辉三角的每一行,我们需要先获取当前行的上一行preRow,进而才能得到上一行的第 j 列和第 j - 1列的值。

中间元素添加完后再进行尾部元素1的添加。

再将创建好的每一行temp列表添加到list中,然后返回。

这里再补充一个更完整的代码,能在IDEA中打印出列表看到效果:

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
public class Test {
    public List<List<Integer>> generate(int numRows) {
       List<List<Integer>> list = new ArrayList<>();
        if(numRows <= 0){
            return list;
        }
       List<Integer> list1 = new ArrayList<>();
       list1.add(1);
       list.add(list1);
       for(int i = 1; i < numRows;i++){
           //每一行的开始
           List<Integer> temp = new ArrayList<>();
           temp.add(1);
           //每一行中间
           List<Integer> prerow = list.get(i-1);//当前行的前一行
           for(int j = 1; j < i; j++){
               int val1 = prerow.get(j);
               int val2 = prerow.get(j - 1);
               int value = val1 + val2;
               temp.add(value);
           }
           //每一行末尾
           temp.add(1);
           list.add(temp);
       }
       return list;
    }

    public static void main(String[] args) {
        Test test = new Test();
        Scanner in = new Scanner(System.in);
        System.out.println(test.generate(in.nextInt()));
    }
}

 可以看到成功运行


 本次的题目讲解结束啦~🎉🎉

🌹感谢支持!🌹 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1964835.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

用60行python代码制作一个扫雷

扫雷游戏&#xff08;Minesweeper&#xff09;是一个经典的逻辑游戏&#xff0c;玩家需要在一个包含隐藏地雷的网格中标记出所有地雷的位置&#xff0c;同时避免触发它们。下面&#xff0c;我将提供一个简单的Python扫雷游戏实现&#xff0c;并附带详细的教程。 第一步&#x…

基于cubeMX的STM32的RTC实时时钟实现

1、在仪器仪表的项目开发中&#xff0c;时常需要设备显示当前的日期和时间&#xff0c;这时&#xff0c;可以使用STM32自带的RTC实时时钟模块来实现此功能。这里我们使用STM32F103RCT6单片机芯片为例。 2、cubeMX的设置 &#xff08;1&#xff09;RTC设置 &#xff08;2&…

第十六天内容

上午 静态资源 根据开发者保存在项目资源目录中的路径访问静态资源html 图片 js css 音乐 视频 f12&#xff0c;开发者工具&#xff0c;网络 1、web基本概念 web服务器 &#xff08;web server&#xff09;&#xff1a;也称HTTP服务器&#xff08;HTTP server&…

在线PS懒人快速抠出透明背景(纯色背景+复杂背景抠图操作)

电脑硬盘快爆了&#xff0c;没必要安装个PS了&#xff0c;网上找了几个在线的PS网站&#xff0c;还别说&#xff0c;一般的PS操作都可以满足 我们使用PS通常用的较多的是抠背景操作吧&#xff0c;接下来演示几个在在线PS网站上进行抠背景操作 一、在线PS网站 Photopea&#x…

IDM2024免费绿色纯净下载器,速度提升的秘密!

Internet Download Manager&#xff08;简称IDM&#xff09;是一种高效的下载管理器&#xff0c;它支持多线程下载、断点续传等功能&#xff0c;能够提高下载速度和稳定性。在网络资源日益丰富的今天&#xff0c;一个好用的下载器对于用户来说是非常重要的。本文将介绍IDM的主要…

数据结构初阶(c语言)-排序算法

数据结构初阶我们需要了解掌握的几种排序算法(除了直接选择排序&#xff0c;这个原因我们后面介绍的时候会解释)如下&#xff1a; 其中的堆排序与冒泡排序我们在之前的文章中已经详细介绍过并对堆排序进行了一定的复杂度分析&#xff0c;所以这里我们不再过多介绍。 一&#x…

Redis的集群 高可用

文章目录 Redis基本概念主从复制哨兵模式故障切换集群 Redis基本概念 Redis集群三种模式 主从复制&#xff1a;奇数台 3&#xff1a; 一主两从 哨兵模式&#xff1a;3&#xff1a; 1主两从 cluster&#xff1a;6 主从复制&#xff1a;和mysql的主从复制类似&#xff0c;主…

log4j2漏洞练习(未完成)

log4j2 是Apache的一个java日志框架&#xff0c;我们借助它进行日志相关操作管理&#xff0c;然而在2021年末log4j2爆出了远程代码执行漏洞&#xff0c;属于严重等级的漏洞。apache log4j通过定义每一条日志信息的级别能够更加细致地控制日志生成地过程&#xff0c;受影响的版本…

基于YOLOv8的道路裂缝坑洼检测系统

基于YOLOv8的道路裂缝坑洼检测系统 (价格88) 包含 【“裂缝”,“凹坑”】 2个类 通过PYQT构建UI界面&#xff0c;包含图片检测&#xff0c;视频检测&#xff0c;摄像头实时检测。 &#xff08;该系统可以根据数据训练出的yolov8的权重文件&#xff0c;运用在其他检测系…

C++初学者指南-5.标准库(第二部分)--序列重新排序算法

C初学者指南-5.标准库(第二部分)–序列重新排序算法 文章目录 C初学者指南-5.标准库(第二部分)--序列重新排序算法移位元素reverse / reverse_copyrotate / rotate_copyshift_leftshift_rightshuffle 排序sortstable_sortpartial_sort / partial_sort_copynth_elementis_…

MD5加密的好处

MD5加密的好处主要包括&#xff1a; 1.快速计算&#xff1a;MD5可以非常快速地对任意大小的数据计算出128位的哈希值&#xff0c;这使得它在处理大量数据时非常高效。 2.抗碰撞性&#xff1a;理论上&#xff0c;要找到两个不同的输入数据生成相同的MD5摘要是非常困难的&#xf…

jQuery来写员工新增和删除(程序默写练习)

目录 一、实现功能: 二、涉及知识点 1、函数的写法&#xff1a; 2、confirm函数 3、获取父节点&#xff0c;以及通过父节点获取指定类型和位置的子节点 3、删除节点元素 4、获取节点元素的文本内容 5、val()函数和text()函数的区别 6、创建一个节点 7、挂载节点、插入…

【香橙派系列教程】(三)常用外设开发

【三】常用外设开发 文章目录 【三】常用外设开发1. wiringPi外设SDK安装2.蜂鸣器BB响1.怎么将其他文件夹里面的文件复制到目前的文件夹&#xff1f;2.修改vim编辑器的tab缩进,显示行数3.蜂鸣器配合时间函数开发 小插曲&#xff1a;shell脚本3.超声波测距1. 测距原理基本说明2.…

TapData 信创数据源 | 国产信创数据库 TiDB 数据迁移指南,加速国产化进程,推进自主创新建设

随着国家对自主可控的日益重视&#xff0c;目前在各个行业和区域中面临越来越多的国产化&#xff0c;采用有自主知识产权的国产数据库正在成为主流。长期以来&#xff0c;作为拥有纯国产自研背景的 TapData&#xff0c;自是非常重视对于更多国产信创数据库的数据连接器支持&…

EasyTwin的动画系统已经到了next level?快来一探究竟!

在实际的数字孪生项目场景建设中&#xff0c;水利项目中的洪水推演、工业领域的工程施工模拟、车间产线运转、机械装置和零件配置展示等项目场景&#xff0c;都对动画效果有很强的使用需求&#xff0c;这是对渲染软件和设计师能力的极大考验&#x1f198;。 别担心&#xff01…

使用人工智能在乳腺癌筛查中的早期影响指标| 文献速递-AI辅助的放射影像疾病诊断

Title 题目 Early Indicators of the Impact of Using AI in Mammography Screening for Breast Cancer 使用人工智能在乳腺癌筛查中的早期影响指标 01 文献速递介绍 基于人群的乳腺癌筛查通过使用乳房X线摄影成功地降低了乳腺癌的死亡率&#xff0c;但这给乳腺放射科医生…

【通俗理解】自相似性探索——从分形到递归的奇妙之旅

【通俗理解】自相似性探索——从分形到递归的奇妙之旅 自相似性的奇妙比喻 你可以把自相似性比作一个“无限镜子”&#xff0c;它能够在不同的尺度上反射出相同的图案或结构。就像是在一面两面镜之间放置一个物体&#xff0c;镜子中的倒影会无限重复&#xff0c;每个倒影都与原…

韦东山瑞士军刀项目自学之中断控制LED

使用库函数设置外部中断控制LED 重点&#xff1a;在设置GPIO为外部中断控制源时&#xff0c;你至少要先检查一下信号是不是来自于你所设置的那个端口&#xff01;因为EXTI并不是对每个端口单独引线&#xff0c;而是将所有组的同编号的部分接口只用一个EXTI进行控制&#xff0c…

【最新】cuda和cudnn和显卡驱动的对应关系

NV官方文档Support Matrix — NVIDIA cuDNN v9.2.1 documentation下列的非常清楚&#xff0c;如图&#xff1a;

Cocos Creator2D游戏开发(9)-飞机大战(7)-爆炸效果

这个爆炸效果我卡在这里好长时间,视频反复的看, 然后把代码反复的测试,修改,终于给弄出来 视频中这段,作者也是修改了好几次, 跟着做也走了不少弯路; 最后反正弄出来了; 有几个坑; ① 动画体创建位置是enemy_prefab ② enemy_prefab预制体下不用放动画就行; ③ 代码中引用Anima…