代码随想录算法训练营 第三天 链表 Leetcode203 移除链表元素 Leetcode707 设计链表 Leetcode 206 反转链表

Leetcode203 移除链表元素 

题目链接

注意 为了使后续节点方式统一  要人为设置链表头节点

链表的处理 一定要明白如何找前置节点

/*** 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) {if(head == null){return head;}ListNode dummy = new ListNode(-1,head);ListNode pre = dummy;ListNode now = head;while(now != null){if(now.val == val){pre.next = now.next;}else{pre = now;}now = now.next;}return dummy.next;}
}

Leetcode 707 设计链表

题目链接

注意设计链表 要掌握 ::设计链表节点,设计头节点,设计链表长度,掌握如何查找前置节点,和当前节点

class ListNode{int val;ListNode next;ListNode() {}ListNode(int val) {this.val = val;}
}class MyLinkedList {int size;ListNode head;public MyLinkedList() {this.size = 0;head = new ListNode(-1);}public int get(int index) {if (index < 0 || index >= size) {return -1;}ListNode cur = head;for (int i = 0; i <= index; i++) {cur = cur.next;}return cur.val;}public void addAtHead(int val) {addAtIndex(0, val);}public void addAtTail(int val) {addAtIndex(size, val);}public void addAtIndex(int index, int val) {if (index <= size) {ListNode pre = head;ListNode p = new ListNode(val);for (int i = 0; i < index; i++) {pre = pre.next;}p.next = pre.next;// if(index == size){//     p.next = null;// }else{//     p.next = pre.next;// }pre.next = p;size++;}}public void deleteAtIndex(int index) {if (index < 0 || index >= size) {return;}ListNode pre = head;for (int i = 0; i < index; i++) {pre = pre.next;}pre.next = pre.next.next;size--;}
}/*** Your MyLinkedList object will be instantiated and called as such:* MyLinkedList obj = new MyLinkedList();* int param_1 = obj.get(index);* obj.addAtHead(val);* obj.addAtTail(val);* obj.addAtIndex(index,val);* obj.deleteAtIndex(index);*/

 Leetcode 206 反转链表

题目链接

 利用双指针思想 直接原地反转 不用新的空间

改变指针方向

首先定义一个cur指针,指向头结点,再定义一个pre指针,初始化为null。

然后就要开始反转了,首先要把 cur->next 节点用tmp指针保存一下,也就是保存一下这个节点。

为什么要保存一下这个节点呢,因为接下来要改变 cur->next 的指向了,将cur->next 指向pre ,此时已经反转了第一个节点了。

接下来,就是循环走如下代码逻辑了,继续移动pre和cur指针。

最后,cur 指针已经指向了null,循环结束,链表也反转完毕了。 此时我们return pre指针就可以了,pre指针就指向了新的头结点

/*** 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 reverseList(ListNode head) {ListNode dummy = new ListNode(-1,head);ListNode cur = head;ListNode pre = null;ListNode tmp = null;while(cur!=null){tmp = cur.next;cur.next = pre;pre = cur;cur = tmp;}return pre;}
}

 

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

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

相关文章

互联网大厂的缓存策略:抵抗超高并发的秘密武器,已开源!

大家好,我是冰河~~ 最近,有小伙伴私信我:冰哥,我最近出去面试,面试官问我如何设计缓存能让系统在百万级别流量下仍能平稳运行,我当时没回答上来。接着,面试官问我之前的项目是怎么使用缓存的,我说只是缓存了一些数据。当时确实想不到缓存还有哪些用处,估计这次面试是挂…

Solution Set #4

搬了以前的博客。大概都是 \(2023\) 年做的。 38. P5369 状压最大前缀和的集合。 dp 算一下符合条件的集合,要求任意后缀和 \(\ge 0\),枚举结尾元素转移即可。后面的就是任意前缀和 \(<0\)。 39.「联合省选 2021 A | B」图函数 \(f(u,G)\) 含义,有多少 \(v\) 满足存在 \(…

在 Kubernetes 云平台上训练和部署生成式 AI 大模型

近年来,生成式 AI 凭借其卓越的技术在各个领域掀起了巨大的轰动。通过大模型,AI 能够创造出逼真的文本、图像、音频等作品,甚至涉足音乐、绘画等艺术领域。这项技术不仅在娱乐、创意产业中大放异彩,还在医疗、教育等领域展现出广阔的应用前景。生成式 AI 的蓬勃发展引发了人…

win 11取消锁屏的弹出的广告設置

【问题】:安装了WIN 11后,在屏保时,默认会看到天气和其他的无关信息。如下图所示 如果是家用电脑没有太多影响,但办公电脑的话,让别人看到这些与工作无关的信息,避免同事误会,最好能取消这些设置。 【解决方法】:通过电脑配置,可取消显示这些与工作无关的信息,具体的…

2. 第二型曲面积分

掌握曲面侧的概念。掌握第二型曲面积分的定义和计算公式(特别要注意参数方程给出的光滑曲面的计算公式中正负号的选择)。了解两种曲面积分的关系。 重点习题:例1、例2 难点:将第二型曲面积分化为重积分时如何确定正负号。 显性形式时,法线方向与坐标轴正向成锐角时取正号,…

【译】通过出色的开发人员体验,将乐趣最大化,将痛苦最小化

有一条通往开发者幸福的道路——开发者可以更多地专注于编码,而不是运维;在那里他们可以以创造力的速度进行创新;他们可以快速发展,而不必担心管理他们的应用程序所依赖的基础设施。未来总是由开发者开始。他们决定了创新的速度,在今天这个生成式人工智能的时代,这一点从…

C#/.NET/.NET Core优秀项目和框架2024年5月简报

前言 公众号每月定期推广和分享的C#/.NET/.NET Core优秀项目和框架(每周至少会推荐两个优秀的项目和框架当然节假日除外),公众号推文中有项目和框架的介绍、功能特点、使用方式以及部分功能截图等(打不开或者打开GitHub很慢的同学可以优先查看公众号推文,文末一定会附带项…

读AI未来进行式笔记05元宇宙与XR

读AI未来进行式笔记05元宇宙与XR1. 元宇宙 1.1. 元宇宙(Metaverse)的概念起源于美国作家尼尔斯蒂芬森于1992年出版的科幻小说《雪崩》 1.1.1. 书中描述的是一个和现实世界平行但又紧密联系的超现实主义的三维数字虚拟空间,在现实世界中地理位置彼此…

NPU技术基础杂谈

NPU技术基础杂谈 NPU 基础 近年来,随着人工智能技术的飞速发展,AI 专用处理器如 NPU(Neural Processing Unit)和 TPU(Tensor Processing Unit)也应运而生。这些处理器旨在加速深度学习和机器学习任务,相比传统的 CPU 和 GPU,它们在处理 AI 任务时表现出更高的效率和性能…

解决历理 win11延迟系统更新时间

Win11系统更新中,暂停更新是有时间限制的,默认最多只能暂停 5 周更新,之后需要暂停更新就要先更新,因此有些用户觉得暂停更新的时间太短了,这篇文章是本站给大家分享的Win11增加系统暂停更新时间教程。1、首先,按键盘上的【 Win + X 】组合键,或右键点击任务栏上的【Win…

PHP历理 PhpStorm的代码换行

打开 文件 -> 设置 -> 编辑器 -> 常规 -> 自动换行,勾选中“对这些文件进行软换行” *.php;*.js;*.html效果图: