当前位置: 首页 > news >正文

【算法训练营Day03】链表part1

文章目录

  • 链表基础理论
  • 移除链表元素
  • 设计链表
  • 反转链表

链表基础理论

几个需要关注的知识点:

  • 链表与数组的不同之处就在于:链表在内存中不一定是连续的,可以是离散存储的,他们之间通过指针进行连接。这也就决定了链表是不能随机查询的,只能通过指针顺藤摸瓜进行顺序查询。
  • 在数组中删除和添加操作会影响到后续的所有元素,而链表是通过指针链接,我们在删除和添加的时候,是对指针所指元素进行修改。
  • 数组的长度在初始化的时候就已经定下来了,而链表的长度是可以不固定的,因为其离散的存在于内存之中。
  • 链表的增加、删除操作一般可以引入一个虚拟头节点完成,使逻辑更加简洁,可以无需考虑头节点的更新以及边界情况的处理。
    • 要是有虚拟头节点,头节点就固定为虚拟头节点的下一个节点,所有的插入和删除操作都能以统一的方式进行处理。

Java语言的单链表定义:

public class ListNode {// 结点的值int val;// 下一个结点ListNode next;// 节点的构造函数(无参)public ListNode() {}// 节点的构造函数(有一个参数)public ListNode(int val) {this.val = val;}// 节点的构造函数(有两个参数)public ListNode(int val, ListNode next) {this.val = val;this.next = next;}
}

移除链表元素

题目链接:203. 移除链表元素

删除逻辑:

  • 首先为链表增添一个虚拟头节点
  • 然后从头节点开始遍历整个链表找到要删除的元素
  • 执行删除逻辑必不可少的两个节点就是删除节点的前缀节点和后缀节点
  • 然后通过指针的修改完成链表的删除操作

代码如下:

/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode() {}*     ListNode(int val) { this.val = val; }*     ListNode(int val, ListNode next) { this.val = val; this.next = next; }* }*/
class Solution {public ListNode removeElements(ListNode head, int val) {ListNode virtualHead = new ListNode(-1,head);ListNode pointer = virtualHead;while(pointer != null && pointer.next != null) {if(pointer.next.val == val) {pointer.next = pointer.next.next;continue;}pointer = pointer.next;}return virtualHead.next;}
}

设计链表

设计链表:707. 设计链表

逻辑不是很难,主要是调试解决一些细枝末节的问题。重点主要是了解链表的删除、添加逻辑(在有头节点的情况下)

代码如下:

class MyLinkedList {int val;MyLinkedList next;int length;public MyLinkedList() {val = -1;next = null;length = 0;}public MyLinkedList(int val,MyLinkedList next) {this.val = val;this.next = next;}public int get(int index) {if(index >= length || index < 0) {return -1;}int count = index + 2;MyLinkedList pointer = this;while(count > 0) {if(count == 1) return pointer.val;count -= 1;pointer = pointer.next;}return -1;}public void addAtHead(int val) {MyLinkedList addNode = new MyLinkedList(val,this.next);this.next = addNode;length += 1;}public void addAtTail(int val) {MyLinkedList pointer = this;while(pointer.next != null) pointer = pointer.next;MyLinkedList addNode = new MyLinkedList(val,null);pointer.next = addNode;length += 1;}public void addAtIndex(int index, int val) {if(index > length || index < 0) {return;}else if(index == length) {addAtTail(val);}else if(index == 0){addAtHead(val);}else {int count = index + 1;MyLinkedList pointer = this;while(count > 0 && pointer.next != null) {if(count == 1) {MyLinkedList addNode = new MyLinkedList(val,pointer.next);pointer.next = addNode;}count -= 1;pointer = pointer.next;}length += 1;}}public void deleteAtIndex(int index) {if(index >= length || index < 0) {return;}else {int count = index + 1;MyLinkedList pointer = this;while(count > 0 && pointer.next != null) {if(count == 1) {pointer.next = pointer.next.next;}count -= 1;pointer = pointer.next;}length -= 1;}}
}

反转链表

题目链接:206. 反转链表

解题逻辑:在遍历链表的同时,使用头插法创建一个新链表,得到的新链表就是反转后的链表。

代码如下:

class Solution {public ListNode reverseList(ListNode head) {ListNode reverseResultVirtualHead = new ListNode();ListNode pointer = head;while(pointer != null) {ListNode currentNode = new ListNode(pointer.val,null);currentNode.next = reverseResultVirtualHead.next;reverseResultVirtualHead.next = currentNode;pointer = pointer.next;}return reverseResultVirtualHead.next;}
}

相关文章:

  • Odoo OWL 框架深度研究(VIP10万字版)
  • 历年西安电子科技大学计算机保研上机真题
  • Linux-pcie ranges介绍
  • Java调用C++教程:JNI与JNA两种方式详解
  • 分库分表的常见策略
  • 推荐3个优秀wordpress主题
  • 如何通过一次需求评审,让项目效率提升50%?
  • 《认知觉醒》第一章——大脑:一切问题的起源
  • Google Play推出新功能:用户可直接向Gemini提问应用相关问题
  • 计算机的发展历史:从计算工具到智能时代的跨越
  • 推荐系统排序指标:MRR、MAP和NDCG
  • redis缓存与数据库协调读写机制设计
  • docker不用dockerfile
  • 【Docker 从入门到实战全攻略(一):核心概念 + 命令详解 + 部署案例】
  • uniapp使用Canvas生成电子名片
  • 西藏建筑安全员 B 证考试中常见的 单选题及解析
  • 关于xilinx pcie ip core管脚分配出现布局布线报错问题说明
  • 沉浸式 “飞进” 鸟巢:虚拟旅游新体验​
  • 【MySQL】MVCC与Read View
  • SpringBoot WebMvcConfigurer使用Jackson统一序列化格式化输出
  • 做网站购买什么/seo服务的内容
  • 跨境独立站怎么运营/百度爱采购平台官网
  • 房山区网站建设/公司网站建设费用多少
  • 网站调用时间/南宁网站建设公司排行
  • 做哪类网站赚钱/百度学术官网入口网页版
  • 如何在网站插入地图/搜索引擎 磁力吧