数据结构之ArrayList与顺序表(下)
找往期文章包括但不限于本期文章中不懂的知识点:
个人主页:我要学编程(ಥ_ಥ)-CSDN博客
所属专栏:数据结构(Java版)
目录
ArrayList的具体使用
118. 杨辉三角
扑克洗牌算法
接上篇:数据结构之ArrayList与顺序表(上)-CSDN博客
ArrayList的具体使用
118. 杨辉三角
给定一个非负整数
numRows,生成「杨辉三角」的前numRows行。在「杨辉三角」中,每个数是它左上方和右上方的数的和。
示例 1:
输入: numRows = 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]示例 2:
输入: numRows = 1 输出: [[1]]
1 <= numRows <= 30
分析:首先是一个杨辉三角的问题,杨辉三角其实就是一个只有一半的二维数组。

public class Test {public static void main(String[] args) {// 打印杨辉三角Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();int count = 0;// 创建一个n行n列的二维数组int[][] array = new int[n][n];for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {if (i == j) {array[i][j] = 1;}else if (j == 0) {array[i][j] = 1;}else {// 只有从第二行开始才会有下面的规律if (i >= 2) {array[i][j] = array[i-1][j] + array[i-1][j-1];}}}}for (int[] x:array) {for (int y:x) {if (y != 0) {System.out.print(y+" ");}}System.out.println();}}
}
打印结果:

注意:杨辉三角还有一个规律就是第 i-1 行有 i 个元素。
这里主要的难点是:List<List<Integer>> 这个代码的意思是什么?分开看,List<Integer> 这个代码的意思是有一个线性表,这个线性表中存放的是 Integer 类型。List<List<Integer>> 难道这个代码的意思是有一个线性表,这个线性表里面存放的是一个线性表?没错!不过这个不叫线性表了。如果我们把这个List看成一个数组,那就是一个数组里面存放的是一个一个的数组元素,然后这些数组元素里面的元素是一个一个的整形包装类。这就是二维数组嘛!二维数组里面是一个一个的一维数组,而一维数组里面是一个一个的整型元素。
例如:
public class Test {public static void main(String[] args) {// 二维数组// 根据顺序表的特点这个二维数组为0行0列List<List<Integer>> list = new ArrayList<>(); //二维数组的初始化list.add(new ArrayList<>()); // 二维数组的元素是一维数组list.add(new ArrayList<>()); // 二维数组的元素是一维数组list.add(new ArrayList<>()); // 二维数组的元素是一维数组// 一维数组的初始化list.get(0).add(10); // list.get(0)得到的是下标为0的一维数组,接着尾插10list.get(1).add(20); // list.get(1)得到的是下标为1的一维数组,接着尾插20list.get(2).add(30); // list.get(2)得到的是下标为2的一维数组,接着尾插30}
}
画图理解:

上面搞懂了,就可以开始做题了。这个题目的意思就是让我们把存放杨辉三角二维数组改成一个ArrayList。
根据我们用二维数组做题时的代码改编一下就可以了。
下面是改编的代码:
方法一:
public class Test {public static List<List<Integer>> generate(int numRows) {// 创建一个二维数组List<List<Integer>> list = new ArrayList<List<Integer>>();for (int i = 0; i < numRows; i++) {// 不用下标直接尾插也是可以的list.add(i, new ArrayList<>());}// 开始为二维数组存放元素for (int i = 0; i < numRows; i++) {List<Integer> list1 = list.get(i);// 注意这里j的条件for (int j = 0; j <= i; j++) {if (i == j) {list1.add(1);}else if (j == 0) {list1.add(1);}else if (i >= 2) {// 实现这个代码:a[i][j] = a[i-1][j]+a[i-1][j-1];// 得到i-1下标数组的j位置的值 得到i-1下标数组的j-1位置的值// 这个写法有问题。就像:3 = 5// list.get(i).get(j) = list.get(i-1).get(j) + list.get(i-1).get(j-1);// 这个就是对上面的代码进行翻译一下int t = list.get(i - 1).get(j) + list.get(i - 1).get(j - 1);list1.add(j , t);}}}return list;}public static void main(String[] args) {List<List<Integer>> listList = generate(5);for (List<Integer> list : listList) {for (Integer x : list) {System.out.print(x+" ");}System.out.println();}}
}
方法二:
public class TestDrive {public static List<List<Integer>> generate(int numRows) {// 创建一个二维数组List<List<Integer>> list = new ArrayList<List<Integer>>();for (int i = 0; i < numRows; i++) {// 不用下标直接尾插也是可以的list.add(i, new ArrayList<>());// 为二维数组的每一位元素的初始化为0for (int j = 0; j < numRows; j++) {list.get(i).add(j,0);}}// 开始为二维数组存放元素for (int i = 0; i < numRows; i++) {List<Integer> list1 = list.get(i);// 注意这里的j和方法进行区别for (int j = 0; j < numRows; j++) {if (i == j) {// 因为所有元素都有初始值了,所以这里就都是set而不是addlist1.set(j,1);}else if (j == 0) {list1.set(j,1);}else if (i >= 2) {int t = list.get(i - 1).get(j) + list.get(i - 1).get(j - 1);list1.set(j , t);}}}return list;}public static void main(String[] args) {List<List<Integer>> listList = generate(5);for (List<Integer> list : listList) {for (Integer x : list) {if (x != 0) {System.out.print(x+" ");}}System.out.println();}}
}
方法一与方法二的区别:
方法二就是完全对前面代码的改编。因为前面我们在创建一个二维数组的同时是进行了初始化的,所以这里的所有元素都是有初始值的。但我们用顺序表来创建二维数组的时候,如果没有初始化,那么其值就是null,这个是不能参与运算的。因此,我们要手动的置为0,这样就可以参与运算了,否则就会发生异常。
方法一就是改进了方法二的不足之处。既然你不初始化,在运算时,会发生异常,那么我就把你的范围卡在只参与运算的部分。也就是 j <= i 。我们仔细观察会发现杨辉三角是一个等腰直角三角形。如下图:

杨辉三角练习完了,接下来,就要进入重磅戏了:扑克洗牌算法。
扑克洗牌算法
要求:
1. 生成一副扑克牌。
2. 并且把这副扑克牌打乱。
3. 发给3个人,每人每轮发一张,总共发5轮。
一张一张的牌,一张牌包括牌面值和花色
// 一张牌
public class Card {public int rank; // 牌面值public String suit; // 对应的花色public Card(int rank, String suit) {this.rank = rank;this.suit = suit;}@Overridepublic String toString() {return ""+suit+rank+" ";}
}
有了一张一张的牌,就可以生成一副牌和存放牌的容器,也就是顺序表
public class Cards {// 生成牌的四色public static final String suit[] = {"♠","♣","♥","♦"};public List<Card> cardList;// 在new一个对象的时候,就会生成存储一副牌的数组public Cards() {this.cardList = new ArrayList<>();}// 生成一副牌// 为了方便,这里的牌面值都用数字表示public List<Card> generateCards() {for (int i = 1; i <= 14; i++) {int count = 0;for (int j = 0; j < suit.length; j++) {// 生成一张牌Card card = new Card(i, suit[j]);// 把牌存放到数组中cardList.add(card);if (i > 13 && count < 2) {count++;}if (count == 2) {break;}}}return cardList;}
}
接下来就是要开始洗牌了。
// 洗牌public void shuffle() {// 通过随机下标进行交换Random random = new Random();// i=0就是自己和自己交换了for (int i = cardList.size()-1; i > 0; i--) {// 生成[0,i)之间的值,也就是[0,i-1]int index = random.nextInt(i);swap(cardList, index, i);}}private void swap(List<Card> cardList, int index, int i) {// 交换index和i下标对应的数组元素// int tmp = a; a = b; b = tmp;Card tmp = cardList.get(i);// 把i下标的值,改为index下标对应的值cardList.set(i, cardList.get(index));cardList.set(index, tmp);}
发牌
// 发牌// 给3人发5轮牌,每人每轮发一张public List<List<Card>> dealCards() {// 创建一个二维数组List<List<Card>> listList = new ArrayList<>();for (int i = 0; i < 3; i++) {listList.add(new ArrayList<>());}for (int i = 0; i < 5; i++) {for (int j = 0; j < 3; j++) {// 第j个人拿到第0下标的牌listList.get(j).add(cardList.get(0)); // 假设从最上面开始拿// 每拿一张就少一张cardList.remove(0);}}return listList;}
测试:
public class Test {public static void main(String[] args) {// 生成一副牌Cards cards = new Cards();List<Card> cardList = cards.generateCards();System.out.println(cardList);// 开始洗牌——将牌的顺序打乱cards.shuffle();System.out.println(cardList);// 开始发牌List<List<Card>> listList = cards.dealCards();// 查看结果int i = 1;for (List<Card> list: listList) {System.out.print("第"+i+"个人拿到的牌:");for (Card x : list) {System.out.print(x+" ");}i++;System.out.println();}}
}
好啦!本期 数据结构之ArrayList与顺序表(下)的学习就到此结束啦!我们下一期再一起学习吧!
相关文章:
数据结构之ArrayList与顺序表(下)
找往期文章包括但不限于本期文章中不懂的知识点: 个人主页:我要学编程(ಥ_ಥ)-CSDN博客 所属专栏:数据结构(Java版) 目录 ArrayList的具体使用 118. 杨辉三角 扑克洗牌算法 接上篇:数据结构之ArrayLis…...
openi启智社区 aarch64 npu环境安装飞桨paddlepaddle和PaddleNLP(失败)
以前在启智社区都是编译安装飞桨,这回看到飞桨提供了npu安装包,兴冲冲的以为安装很简单。 之所以安装飞桨,是因为想在启智社区的启智大脑调试环境使用最新的PaddleNLP,结果报错:No module named paddle.nn.layer.laye…...
【漏洞复现】多客圈子论坛系统 httpGet 任意文件读取漏洞
0x01 产品简介 多客圈子论坛系统是一种面向特定人群或特定话题的社交网络,它提供了用户之间交流、分享、讨论的平台。在这个系统中,用户可以创建、加入不同的圈子,圈子可以是基于兴趣、地域、职业等不同主题的。用户可以在圈子中发帖、评论、…...
46-1 护网溯源 - 钓鱼邮件溯源
一、客户提供钓鱼邮件样本 二、行为分析 三、样本分析 对钓鱼邮件中的木马程序1111.exe文件进行了分析,提交了360安全大脑沙箱云和微步在线云沙箱。 360安全大脑沙箱云显示,该1111.exe文件存在危险,因此在解压时需要谨慎操作,以免触发木马程序。 建议使用360压缩软件进行…...
鸿蒙低代码开发一个高频问题
在版本是DevEco Studio 3.1.1 Release,SDK是3.1.0(API9)。 创建和设计的visual文件经常会遇到无法渲染的情况,或者自定义组件在Custom列表中突然不见了的情况。 有以下报错信息的: JSON schema validation error: data/visualModel/value/…...
关于使用南墙waf防护halo网站主页请求404报错的解决方案
文章目录 环境说明问题展示原因探究解决方法 环境说明 在1panel应用商店,部署南墙waf(docker版)halo(2.16.1社区版)注意部署过程中注意uuwaf必须勾选允许外部访问,halo可以不勾选[这里为了证明确实是南墙waf的原因,选择勾选] 问题展示 使…...
Elasticsearch 认证模拟题 - 13
一、题目 集群中有索引 task3,用 oa、OA、Oa、oA 查询结构是 4 条,使用 dingding 的查询结果是 1 条。通过 reindex 索引 task3 为 task3_new,能够使 task3_new 满足以下查询条件。 使用 oa、OA、Oa、oA、0A、dingding 查询都能够返回 6 条…...
Day25 首页待办事项及备忘录添加功能
本章节,完成首页待办事项及备忘录添加功能 一.修改待办事项和备忘录逻辑处理类,即AddMemoViewModel和AddTodoViewModel 在 AddMemoViewModel逻辑处理类中,为了支持与其关联的View视图文件的数据绑定,需要定义一个与视图文件相匹配的实体类 Model。这个Model将包含 View中…...
SpringBoot——全局异常处理
目录 异常 项目总结 新建一个SpringBoot项目 pom.xml Result(通用的响应结果类) MyBusinessException自定义异常类 GlobalExceptionHandler全局异常处理类 ExceptionController控制器 SpringbootExceptionApplication启动类 参考文章:…...
SpringBoot+Vue教师工作量管理系统(前后端分离)
技术栈 JavaSpringBootMavenMySQLMyBatisVueShiroElement-UI 角色对应功能 教师管理员 功能截图...
华为OD技术面试-最长回文串-2024手撕代码真题
题目:最长回文串 给定一个包含大写字母和小写字母的字符串 s ,返回 通过这些字母构造成的 最长的 回文串 的长度。 在构造过程中,请注意 区分大小写 。比如 "Aa" 不能当做一个回文字符串。 示例 1: 输入:s = "abccccdd" 输出:7 解释: 我们可以构造的最…...
Python实现连连看8
4 游戏开始 连连看游戏实际上主要完成的是对玩家鼠标点击事件的处理,也就是对鼠标点击事件的响应。 4.1 添加鼠标点击事件响应 在“1.3.4 在窗口上铺设画布”中提到的将画布pack()到窗口代码之前,写入如下代码,其功能是为鼠标点击事件添加响应。 canvas.bind(<Button…...
[Cloud Networking] Layer Protocol (continue)
文章目录 1. STP / RSTP / MSTP Protocol1.1 STP的作用1.2 STP 生成树算法的三个步骤1.3 STP缺点 2. ARP Protocol3. DHCP Protocol3.1 DHCP 三种分配方式3.2 DHCP 攻击 4. IPSEC / MACSEC 1. STP / RSTP / MSTP Protocol 1.1 STP的作用 消除二层环路:通过阻断冗余…...
人工智能在交通与物流领域的普及及应用
文章目录 🐋引言 🐋自动驾驶 🦈自动驾驶汽车 🐡应用现状 🐡技术实现 🐡实现过程及代码 🐋智能交通管理 🦈应用现状 🦈技术实现 🦈实现过程及代码 &…...
JVM学习-详解类加载器(二)
双亲委派机制 双亲委派优势 避免类的重复加载,确保一个类的全局唯一性 Java类随着它的类加载器一起具备了一种带有优先级的层次关系,通过这种层次关系可以避免类的重复加载,当父类已经加载了该类,就没有必要子ClassLoader再加载…...
数字校园的优势有哪些
数字化时代下,数字校园已成为教育领域一股显著趋势。数字校园旨在借助信息技术工具对传统校园进行改造,提供全新的教学、管理和服务方式。那么,数字校园究竟具备何种优势?现从三个方面为您详细介绍。 首先,数字校园为教…...
DexCap——斯坦福李飞飞团队泡茶机器人:更好数据收集系统的原理解析、源码剖析
前言 2023年7月,我司组建大模型项目开发团队,从最开始的论文审稿,演变成目前的两大赋能方向 大模型应用方面,以微调和RAG为代表 除了论文审稿微调之外,目前我司内部正在逐一开发论文翻译、论文对话、论文idea提炼、论…...
【Mtk Camera开发学习】01 MTK 平台Camera BringUp
本专栏内容针对 “知识星球”成员免费,欢迎关注公众号:小驰行动派,加入知识星球。 #MTK Camera开发学习系列 #小驰私房菜 这篇文章主要介绍MTK 平台,Camera BringUp会涉及到修改的模块。 MTK不同的平台系列,具体修改…...
新能源汽车内卷真相
导语:2025年,我国新能源汽车总产能预计可达3661万辆,如此产能如何消化? 文 | 胡安 “这样卷下去不是办法,企业目的是什么?是盈利,为国家作贡献,为社会作贡献。我们应该有大格局&…...
C 语言实现在终端里输出二维码
Mac 环境安装二维码库 brew install qrencode安装过程报权限问题执行以下命令 sudo chown -R 用户名 /usr/local/include /usr/local/lib chmod uw /usr/local/include /usr/local/lib#include <stdio.h> #include <qrencode.h>void print_qr_code(QRcode *qrcode…...
学校AI率要求越来越严:2026年各高校AIGC检测政策趋势深度分析
学校AI率要求越来越严:2026年各高校AIGC检测政策趋势深度分析 去年毕业的学长可能还不太了解AIGC检测这回事,但今年毕业的同学已经切实感受到了压力——越来越多的高校把AIGC检测纳入了论文审核流程,而且要求还在逐步收紧。 我整理了一些公开…...
墨语灵犀赋能操作系统教学:模拟命令行助手与概念讲解
墨语灵犀赋能操作系统教学:模拟命令行助手与概念讲解 操作系统这门课,很多同学都觉得有点“硬核”。那些抽象的概念,比如进程调度、内存分页,还有一堆看起来冷冰冰的命令行指令,常常让人望而却步。有没有一种方法&…...
啃了3个月Profinet硬骨头:我用C#实现了以太网帧抓包+GSD解析(附踩坑实录)
“威哥,别试了,那台德国老设备的Profinet通信,第三方库要价20万,还不支持定制。” “20万?项目预算才多少!我就不信了,抓包分析GSD解析,我用C#自己撸一套对接方案。” 这段对话发生在…...
Qwen3.5-27B部署教程:从supervisorctl管理到7860端口防火墙配置
Qwen3.5-27B部署教程:从supervisorctl管理到7860端口防火墙配置 1. 环境准备与快速部署 Qwen3.5-27B是一款强大的视觉多模态理解模型,支持文本对话与图片理解功能。本教程将指导您完成从基础部署到高级管理的完整流程。 系统要求: 推荐配…...
Qwen3-TTS-12Hz-1.7B-Base真实案例:K12教育中英文双语朗读生成效果
Qwen3-TTS-12Hz-1.7B-Base真实案例:K12教育中英文双语朗读生成效果 你有没有想过,如果教材里的课文能“开口说话”,而且是用你熟悉的声音、带着丰富的情感来朗读,那会是怎样的学习体验? 在K12教育领域,无…...
计算机毕业设计springboot设备维护小程序 基于SpringBoot的智能化设备运维管理平台设计与实现 企业资产设备全生命周期管理系统的设计与开发
计算机毕业设计springboot设备维护小程序4zs100f8 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。 随着工业4.0和智能制造的深入推进,企业生产设备日益精密化、复杂化…...
监控系统集成避坑指南:ONVIF协议对接常见的5大错误及解决方法(附AS-V1000实测)
ONVIF协议实战避坑手册:从设备对接到故障排查的全链路指南 在智能安防系统集成领域,ONVIF协议作为设备互联的"通用语言",理论上应该让不同厂商的设备实现无缝对接。但现实情况往往是——当你信心满满地点击"发现设备"按钮…...
Nomic-Embed-Text-V2-MoE 在操作系统日志分析中的应用:异常行为模式挖掘
Nomic-Embed-Text-V2-MoE 在操作系统日志分析中的应用:异常行为模式挖掘 1. 引言 想象一下,你负责维护一个大型在线服务,每天服务器会产生上千万条日志。这些日志就像系统的“心电图”,记录着每一次心跳、每一次异常。某天凌晨&…...
5步打造高性能VRChat角色:从模型导入到流畅运行的全流程优化指南
5步打造高性能VRChat角色:从模型导入到流畅运行的全流程优化指南 【免费下载链接】cats-blender-plugin 项目地址: https://gitcode.com/gh_mirrors/cats/cats-blender-plugin 作为一名VRChat创作者,我深知模型优化的痛苦——导入的角色在预览时…...
Hunyuan-OCR-WEBUI功能扩展:从单张识别到批量处理的完整教程
Hunyuan-OCR-WEBUI功能扩展:从单张识别到批量处理的完整教程 1. 引言 在日常工作中,我们经常需要处理大量图片中的文字信息。无论是扫描的文档、拍摄的票据,还是截图中的文字内容,传统的手动录入方式效率低下且容易出错。腾讯混…...

