顺序表 —— OJ题

在上一篇文章中简单介绍了顺序表,这一篇文章讲解下一个比较经典的题:

杨辉三角

先看一下什么是杨辉三角

下面解释:

大概就是这个规律。而 ta 其实就是二维数组 即:

0  1
1  1 1
2  1 2 1
3  1 3 3 1
4  1 4 6 4 1

然后看一下这个题的要求:

意思是 numRows 一个非负数(整数),在根据 numRows 里的整数生成 【杨辉三角 】的“层数”

这是ta给的方法体:

这里的 List <List<Integer>>这个边讲边说

下面说一下 这道题如何解:
首先是步骤:

如果你仔细观察这个图就会发现 ta 的头值和尾值都是 1 而中间的都是运算来的

所以可以将这道题分为 头 中  尾 三部分处理 

头 尾处理比较简单难点是 中 的处理,这时候 再仔细观察 中间的值,是如何得出来的,你会发现:

0  101  1 10 12  1 2 10 1 23  1 3 3 10 1 2 3 4  1 4 6 4 10 1 2 3 4所有的中间值都是由 上一个数组以下标 0 + 1 | 1 + 2 | 2 + 3 
的规律得出下一个数组 1下标 2下标 3下标 的值  如4数组:1下标 = 1+3 、2下标 = 3 + 3 、3下标 = 3+1就可以这样写:
i = 数组
while(ture){
j = 0;
int val = i[j] + i[j+1];
j++;
}

但这时候问题又出现了,以杨辉三角的规律不是那个数组,都有 1 2 3 下标的,这时候就要找条件

的要求了  这时候再仔细看一下图:

0  101  1 10 12  1 2 10 1 23  1 3 3 10 1 2 3 4  1 4 6 4 10 1 2 3 4会发现数组2需要加1次
数组3需要加2次
数组4需要加3次
后面相加的次数依次+1
只有 numRows 等于3时中间值需要加1次,4时加2次.......

这个题最好用顺序表解决 下面看代码:

public List<List<Integer>> generate(int numRows) {List<Integer> list = new ArrayList<>();//List<List<Integer>> ta 的意思就是如果你存放数组(顺序表的底层是数组)的地址//会给这个地址放上 下标  ret是要返回的List<List<Integer>> ret = new ArrayList<>();//处理一层list.add(1);ret.add(list);//处理二层以上for(int i = 1; i<numRows; i++){//头List<Integer> cj = new ArrayList<>();cj.add(1);//中//这里的 get 拿的是数组的整个地址List<Integer> zo = ret.get(i-1);//只有numRows 为3及以上才会运算for(int j = 0; j<i-1; j++){int val = zo.get(j) + zo.get(j+1);cj.add(val);}//尾cj.add(1);ret.add(cj);}return ret;}
List <List<Integer>>:

最后提交一下:

下一篇文章是 单向 无头 不循环链表

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

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

相关文章

基于单片机的防酒驾系统设计

一、引言1.1 研究背景与意义随着社会经济的快速发展&#xff0c;汽车保有量持续攀升&#xff0c;道路交通安全问题愈发凸显。酒后驾驶作为交通事故的主要诱因之一&#xff0c;严重威胁着人们的生命财产安全。据统计&#xff0c;全球每年因酒驾造成的交通事故死亡人数高达数十万…

Redis面试精讲 Day 22:Redis布隆过滤器应用场景

【Redis面试精讲 Day 22】Redis布隆过滤器应用场景 在高并发、大数据量的互联网系统中&#xff0c;如何高效判断一个元素是否存在于集合中&#xff0c;是缓存设计中的关键问题。尤其是在面对缓存穿透——即恶意或无效请求频繁查询不存在的数据&#xff0c;导致数据库压力剧增—…

Spark Shuffle中的数据结构

文章目录1.Shuffle中的三种数据结构2.AppendOnlyMap原理2.1 聚合2.2 扩容2.3 排序2.4 为什么是数组&#xff1f;3.ExternalAppendOnlyMap原理3.1 工作原理3.2 AppendOnlyMap大小估计3.2.1 为什么要估计大小&#xff1f;3.2.2 估计大小浅析3.2.2.1 什么时候采样&#xff1f;3.2.…

告别在线转换风险:本地运行的PDF转Word技术评测

Word文档&#xff08;.docx&#xff09;是可编辑的主流办公格式&#xff0c;支持灵活修改文字、排版、图片、表格等。它的体积仅有5.5M&#xff0c;小巧不占空间&#xff0c;且转换不限文件大小&#xff0c;随用随转&#xff0c;毫无限制。初次使用需完成一次安装&#xff0c;之…

整体设计 符号学与诠释学融合的整体设计框架(本篇暂时命名)--PromptPilot (助手)答问之1

说明 本系列篇&#xff08;分多篇&#xff09;是就前面 已经和腾讯元宝就“整体设计”的讨论内容 再和 PromptPilot &#xff08;助手&#xff09;的再次沟通。但内容做了部分修正一边 更准确和完整。摘要&#xff08;CSDN的AI助手提取的&#xff09;符号学与诠释学融合的整体设…

Font shape `TU/ptm/m/n‘ undefined(Font) using `TU/lmr/m/n‘ instead

一、警告内容 这是 LaTeX 字体选择机制输出的信息。我们可以把 TU/ptm/m/n 分解来看&#xff1a; TU → 编码 (font encoding) TU 表示 Unicode TeX encoding&#xff0c;即新版 XeLaTeX/LuaLaTeX 下的 Unicode 字体编码。 ptm → 字体族 (family) ptm 代表 Times 字体 (PostS…

拒绝造轮子(C#篇)ZLG CAN卡驱动封装应用

拒绝造轮子&#xff08;C#篇&#xff09;ZLG CAN卡驱动封装应用 今天给大家介绍一个封装完善的CAN卡类。 背景 在面对常规开发场景&#xff0c;开发者对复杂SDK进行封装和测试。阅读相关开发资料和理解SDK的DEMO程序。 开篇 如果你也有同样的烦恼&#xff0c;那就来看看今…

机器学习相关算法:回溯算法 贪心算法 回归算法(线性回归) 算法超参数 多项式时间 朴素贝叶斯分类算法

整理了一张“机器学习相关算法与概念速览表”&#xff0c;既包含定义&#xff0c;也配上了容易记住的例子&#xff0c;让大家一眼就能抓住它们的特点&#xff1a; &#x1f916; 机器学习与相关算法&概念 名称定义生动例子典型应用场景回溯算法通过不断尝试和回退来寻找问…

vue+微信小程序 五角星

说明&#xff1a;这个是先画出一个72度菱形&#xff0c;长中长线和短中长线按照一定比例&#xff0c;然后把菱形分层十份&#xff0c;最后再把菱形进行旋转形成五角星&#xff0c;最后显示标签&#xff0c;因为一直对不上所以对标签做了点操作 <template><view class&…

Prometheus + Grafana 深度玩法:从零到智能化监控体系

0. 写在前面&#xff1a;为什么你需要“神器”而非“常用命令老杨折腾监控系统可是有年头了&#xff0c;最早还用过 Cacti、Zabbix&#xff0c;那会儿做个仪表盘都得像雕花一样慢慢刻。后来 Prometheus 出来之后&#xff0c;我的第一反应是&#xff1a;这玩意儿的时间序列和标签…

YOLO、DarkNet和深度学习如何让自动驾驶看得清?

【导读】 本文提出 DarkNet-YOLO 工业级实践框架&#xff0c;通过引入 残差优化结构 与 多尺度特征融合技术&#xff0c;在保持实时检测精度同时显著提升复杂场景适应性。 目录 一、目标检测的进化之路&#xff1a;从“两步走”到“一眼定乾坤” YOLO的核心思想&#xff1a…

使用 HTML5 Canvas 打造炫酷的数字时钟动画

在 Web 开发中&#xff0c;HTML5 的 canvas 元素为我们带来了强大的绘图能力&#xff0c;结合 JavaScript&#xff0c;可以实现各种酷炫的效果。今天&#xff0c;我们将深入剖析一段经典的 彩色数字时钟动画 代码&#xff0c;并理解它是如何通过物理模拟实现数字切换时的炫酷粒…

XCZU6CG-2FFVC900I Xilinx FPGA AMD ZynqUltraScale+ MPSoC

XCZU6CG-2FFVC900I Xilinx FPGA&#xff08; AMD&#xff09;Zynq UltraScale MPSoC 。在处理系统&#xff08;PS&#xff09;方面&#xff0c;XCZU6CG 系列通常集成了 ARM Cortex-A53 应用核与 Cortex-R5 实时核的组合&#xff08;典型为 A53 多核 R5 双核组合&#xff09;&…

Navicat 询问 AI | 优化 SQL 查询

近期&#xff0c;我们发布了 Navicat 17.3 版本。这一版本实现了全方位升级&#xff0c;包括对 AI 功能大升级、支持达梦、金仓、瀚高、支持阿里通义千问等 AI 大模型&#xff0c;支持凝思 OS 以及多项 UI 改进。今天&#xff0c;我们将深入介绍 Navicat AI 功能之“询问 AI ”…

4.6 Vue 3 中的模板引用 (Template Refs)

在 Vue 3 中&#xff0c;ref 是一个核心的响应式 API&#xff0c;但它在模板中还有另一个非常重要的用途&#xff1a;获取对 DOM 元素或子组件实例的直接引用。这就是我们所说的“模板引用”。核心概念目的&#xff1a;让你在父组件中能够直接访问并操作特定的 DOM 元素或子组件…

模式匹配自动机全面理论分析

模式匹配是什么 模式匹配是计算机科学中一个基础且重要的问题&#xff0c;广泛应用于文本编辑、信息检索、网络安全、生物信息学等多个领域。简单来说&#xff0c;模式匹配就是在一个主文本中查找一个或多个特定模式串的出现位置。随着计算机处理能力的提升和数据规模的扩大&am…

AI 搜索时代:引领变革,重塑您的 SEO 战略

随着谷歌转向人工智能驱动的答案&#xff0c;使用以关键字和反向链接为中心的过时和传统的 SEO 策略不再起到任何作用。 由于 Google AI Overviews 和零点击搜索的兴起&#xff0c;自然点击量正在下降&#xff0c;用户无需点击任何网站即可直接在 Google 的搜索结果页面上获得答…

【网站深入seo方法】

目录 ①对于更成熟的网站&#xff0c;简单的index.html的入口文件的seo已经无法满足&#xff0c;需要在商品详情不同商品被搜索时赋予不同的title和description。 ②通过设置站点所有页面都新增Canonical标签&#xff0c;指定规范链接地址给谷歌并规避联盟的重复内容页面。 ③…

ROS move_base 混合功能导航 RealSense D435i + 3D 点云地图 + 楼层切换 + 路径录制 + 路径规划

Mixed-Navigation 这个博客也是记录我们的一个开源项目&#xff0c;其作用是混合功能导航。由于现有的 Fast-Lio-Localization 只实现了定位功能&#xff0c;但对于路径规划和楼层切换没有具体实现&#xff0c;因此我们开出了这个仓库作为参考。该仓库的核心功能如下&#xff…

初识c语言————宏定义和调用

目录&#xff1a;一.不带参数的宏二.带参数宏一.不带参数的宏不带参数的宏是指用#define指令定义的简单文本替换规则&#xff0c;它没有参数列表&#xff0c;直接替换标识符为相应的文本其一般形式为&#xff1a;#define 宏名 文本例如&#xff1a;#define pi 3.14这个代…