ACM金牌选手算法讲解《线性表》
哈喽,大家好,我是编程熊,双非逆袭选手,字节跳动、旷视科技前员工,ACM亚洲区域赛金牌,保研985研究生,分享算法与数据结构、计算机学习经验,帮助大家进大厂~
公众号:『编程熊』
文章首发于: ACM金牌选手算法讲解《线性表》!戳这里!
线性表
LeetCode刷题过程中,常常用到的线性表主要包括以下四个重要的数据结构: 数组、链表、栈、队列。
下面将分别讲解数组、链表、栈和队列。
线性表概述
线性: 这里的线性是逻辑上的连续,而非物理存储的连续。
存储的数据: 线性表是一个有n
个相同类型数据的有序序列。
数组array
介绍
数组是物理存储连续的线性表,其常见的形式为 a[0]、a[1] ... a[n-1]
,a[i-1]
是 a[i]
的前驱,a[i+1]
是 a[i]
的后继。
基本操作
插入
插入元素,要将插入位置后的元素全部向后移动一位。
下图以数组长度为6,数据为0、1、2、3、4、5
,在位置3插入一个元素X举例。
删除
删除元素,要讲删除位置后的元素全部向前移动一位。
下图以数组长度为6,数据为0、1、2、3、4、5
,删除位置3上的元素X举例。
反转
翻转数组,本质是将数组存储的数据进行反转。
下图以数组长度为6,数据为0、1、2、3、4、5
,反转整个数组举例。
例题
LeetCode 27. 移除元素
题意
删除数组中所有等于 val
的元素,返回移除后数组的新长度。要求不使用额外的空间。
示例
输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2]
题解
数组的删除操作,但如何不使用额外的空间呢?因为删除val
后的数组的长度小于等于原数组的长度,因此可以一边将不等于val
的数组放入原数组中,同时判断原数组的数是否等于val
。
代码
class Solution {
public int removeElement(int[] nums, int val) {
// left 存当前nums数组中不等于val的数字数量
int left = 0;
for (int right = 0; right < nums.length; right++) {
if (nums[right] != val) {
nums[left] = nums[right];
left++;
}
}
return left;
}
}
习题推荐
LeetCode 35. 搜索插入位置
链表
介绍
链表的出现是为了解决数组插入、删除带来的线性开销。
区别于数组,链表中的元素可以不连续存储,每一个元素包含该 元素的数据 和 指向链表下一个节点的指针。
基本操作
插入
插入元素,要将插入元素前一个位置的指针指向插入元素本身,将插入元素的指针指向前一个位置。
删除
删除元素,要将 删除元素前一个元素的指针 指向 删除元素后一个元素,代码实现上需要将 删除元素指针指向的位置 记录下来。
下图是以长度为5的链表,删除位置3上的元素为例子。
翻转
翻转链表,可以一边遍历一边用一个临时变量记录当前元素的下一个元素指针所指向的位置,然后再将当前元素的下一个元素指针指向自己。
下图是以长度为5的链表,翻转链表为例子。
例题
1. LeetCode 206. 反转链表
题意
给单链表的头节点 head
,请反转链表,并返回反转后的链表。
示例
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
题解
按上述链表翻转操作思路实现代码。
代码
public ListNode reverseList(ListNode head) {
// pre 存的是当前节点的上一个节点
ListNode prev = null;
// curr 存的是当前链表遍历到节点
ListNode curr = head;
while (curr != null) {
// next 存的是当前节点下一个节点
ListNode next = curr.next;
curr.next = prev;
prev = curr;
curr = next;
}
return prev;
}
习题推荐
- LeetCode237. 删除链表中的节点
- LeetCode 21. 合并两个有序链表
- LeetCode 160. 相交链表
栈和队列
栈介绍
栈被限定必须在栈顶进行插入和删除操作,因此其特点为是后进先出。
下图是栈的插入(入栈)、删除(出栈)示意图。
队列介绍
队列被限定在队头进行删除操作,队尾进行插入操作,因此其特点为先进先出。
下图是队列的插入(入队)、删除(出队)示意图。
基本操作
栈和队列的插入和删除操作上图已解释。
例题
LeetCode 155. 最小栈
题意
设计一个支持 push
,pop
,top
操作,并能在常数时间内检索到最小元素的栈。
push(x)
—— 将元素 x 推入栈中。pop()
—— 删除栈顶的元素。top()
—— 获取栈顶元素。getMin()
—— 检索栈中的最小元素。
示例
输入:
["MinStack","push","push","push","getMin","pop","top","getMin"]
[[],[-2],[0],[-3],[],[],[],[]]
输出:
[null,null,null,null,-3,null,0,-2]
解释:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin(); --> 返回 -3.
minStack.pop();
minStack.top(); --> 返回 0.
minStack.getMin(); --> 返回 -2.
题解
新建辅助栈,辅助栈的栈顶表示原栈所有数字最小值,下面分别讨论题目要求的四种操作,分别如何实现。
push(x)
: 若插入的数字小于等于辅助栈的栈顶元素,则这个数字在原栈是最小值(之一),我们将其插入辅助栈中。pop():
若原栈删除的数字等于辅助栈的栈顶元素,则这个数字在原栈是最小值(之一),我们同时原栈和辅助栈的栈顶元素;反之,只删除原栈栈顶元素。top():
返回原栈的栈顶元素。getMin():
返回辅助栈的栈顶元素。
代码
class MinStack {
public Stack<Integer> s, min_s;
public MinStack() {
s = new Stack<>();
min_s= new Stack<>();
}
public void push(int x) {
s.push(x);
if(min_s.isEmpty() || x <= min_s.peek())
min_s.push(x);
}
public void pop() {
if(s.pop().equals(min_s.peek()))
min_s.pop();
}
public int top() {
return s.peek();
}
public int getMin() {
return min_s.peek();
}
}
习题推荐
LeetCode 20. 有效的括号
End
我是编程熊,双非逆袭选手,字节跳动、旷视科技前员工,ACM亚洲区域赛金牌,保研985研究生,分享算法与数据结构、计算机学习经验,帮助大家进大厂~
公众号:『编程熊』,回复【书】免费领取计算机学习核心资料(从小白到大神)。
ACM金牌选手算法讲解《线性表》的更多相关文章
- ACM金牌选手讲解LeetCode算法《栈和队列的高级应用》
大家好,我是编程熊,双非逆袭选手,字节跳动.旷视科技前员工,ACM金牌,保研985,<ACM金牌选手讲解LeetCode算法系列>作者. 上一篇文章讲解了<线性表>中的数组.链 ...
- ACM金牌选手讲解LeetCode算法《哈希》
大家好,我是编程熊. 往期文章介绍了<线性表>中的数组.链表.栈.队列,以及单调栈和滑动窗口. ACM金牌选手讲解LeetCode算法<线性表> ACM金牌选手讲解LeetCo ...
- ACM金牌选手整理的【LeetCode刷题顺序】
算法和数据结构知识点图 首先,了解算法和数据结构有哪些知识点,在后面的学习中有 大局观,对学习和刷题十分有帮助. 下面是我花了一天时间花的算法和数据结构的知识结构,大家可以看看. 后面是为大家 精心挑 ...
- Java数据结构与算法(1):线性表
线性表是一种简单的数据类型,它是具有相同类型的n个数据元素组成的有限序列.形如如A0,A1,...,An-1.大小为0的表为空表,称Ai后继Ai-1,并称Ai-1前驱Ai. printList打印出表 ...
- 【数据结构与算法】线性表操作(C++)
#include <stdio.h> #define maxSize 100 //定义整型常量maxSize值为100 /*顺序表的结构体定义*/ typedef struct SqLis ...
- 【数据结构与算法】线性表操作(C语言)
#include <stdio.h> #include <stdlib.h> #define OK 1 #define NO 0 #define MAXSIZE 20 type ...
- 算法与数据结构(一) 线性表的顺序存储与链式存储(Swift版)
温故而知新,在接下来的几篇博客中,将会系统的对数据结构的相关内容进行回顾并总结.数据结构乃编程的基础呢,还是要不时拿出来翻一翻回顾一下.当然数据结构相关博客中我们以Swift语言来实现.因为Swift ...
- 线性表的顺序存储设计和实现 - API函数实现
基本概念 设计与实现 插入元素算法 判断线性表是否合法 判断插入位置是否合法 把最后一个元素到插入位置的元素后移一个位置 将新元素插入 线性表长度加1 获取元素操作 判断线性表是否合法 判断位置是否合 ...
- [Algorithm]线性表
一. 线性表基础算法 1.线性表插入操作 1 // 线性表插入操作(在第i(1≤i≤L.length+1)个位置上插入新元素elem) 2 bool InsertSeq( SeqList& L ...
随机推荐
- 聊聊java工程师换工作那些事
最近有个读者在苦恼一件事,那就是有大公司在挖他,他要不要从所在的小公司,跳槽到大公司,前提是两家公司的待遇基本一致.由这个问题结合自己多年的工作经验,来谈谈java工程师要不要跳槽,何时跳槽,怎么跳槽 ...
- openresty 学习笔记一:环境安装
openresty 学习笔记一:环境安装 openresty 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库.第三方模块以及大多数的依赖项.用于方便地搭 ...
- Python+Selenium学习笔记9 - 警告框处理
如下图所示,这种窗口是不能通过前端工具对其进行定位的,这里可以通过switch_to_alert()方法去接受这个弹窗 1 # coding = utf-8 2 3 from selenium imp ...
- Python小白的数学建模课-A3.12 个新冠疫情数模竞赛赛题与点评
新冠疫情深刻和全面地影响着社会和生活,已经成为数学建模竞赛的背景帝. 本文收集了与新冠疫情相关的的数学建模竞赛赛题,供大家参考,欢迎收藏关注. 『Python小白的数学建模课 @ Youcans』带你 ...
- 重型车辆盲区行为检查Behaviours – Heavy Vehicle Blind Spots
重型车辆盲区行为检查Behaviours – Heavy Vehicle Blind Spots VISIBILITY AROUND HEAVY VEHICLES A blind spot is an ...
- 短波红外(SWIR)相机camera
短波红外(SWIR)相机camera AVs Can't Drive Everywhere. Can TriEye's SWIR Camera Help? TriEye的短波红外(SWIR)摄像机能否 ...
- 微调BERT:序列级和令牌级应用程序
微调BERT:序列级和令牌级应用程序 Fine-Tuning BERT for Sequence-Level and Token-Level Applications 为自然语言处理应用程序设计了不同 ...
- Android adb的常用命令
环境部署: 1.下载adb工具 2.下载奇兔刷机(或其它一键刷机软件),将手机与电脑进行连接 3.一键root手机 命令 1.获取设备列表及设备状态:adb devices 如果连接的设备不止一个, ...
- windows 7系统安装与配置Tomcat服务器环境
windows 7系统安装与配置Tomcat服务器环境 学习了一个月的java基础,终于要迈向java web领域.学习java web开发就离不开服务器的支持,由于本人是菜鸟,只好求助度娘谷哥.在此 ...
- LuatOS | 全新在线模拟器,随时随地发挥创意
LuatOS --运行在嵌入式硬件的实时操作系统,开启全新物联网生态. 聚焦嵌入式应用生态,内置功能可支持绝大多数物联网应用场景.深度整合Lua语言,只需少量内存和Flash空间就能运行.不局限于合宙 ...