我在代码随想录|写代码之203. 移除链表元素,707. 设计链表,206. 反转链表

​第一题 ​​ 203. 移除链表元素

题目:

leetcode

思路分析:

我们要删除节点说白了就是将节点移除,将要删除的节点的前一个的next域移动到要删除节点的next域,我们可以这样写当我们运到我们要删除节点然后件他删除,那么怎么删除?我们可以直接让我们要删除的元素找不到。如果我们直接将我们要删除的节点删除那么我们就找不到我们的要删除节点的下一个节点所以我们要将我们的节点进行平移操作,我们平移肯定要早到我们要删除节点的上一个节点,而我们的链表是单向的所以我们不可能回到上一个节点所以我们定义的指针要指向上一个节点,所以我们要通过cur->next去确定我们要删除的节点,这个就是我们的思路。

一刷

在这里插入图片描述

一刷用了块的方法我们不断移动头节点当发现我们的头结点的下一位为我们我删除的值的时候循环将头结点更新,为什么要将头结点的删除和其他结点区分开来,因为我们的头结点可能为空,而尾结点的next域为空所以要将俩端区分。在头节点判断中我们将头结点使用一个指针去操作这样可以让保证我们的头结点始终是我们链表的头部,我们的头结点等于我们头结点的下一个值,也就是说当我们头节点尾我们要删除的值的时候我们要将头节点向后移动然后删除我们的p指针指向的上一个头节点的值为什么是这样因为我们的头节点已经更新了。else后面确定的是尾节点我们可以通过相同的方法去解决因为没有说明区别,然后就是我们对不是俩段节点的处理了,正常的节点移除操作,最后我们返回的我们的头节点

代码

代码解析

上面的代码我们使用了虚拟头节点,在头节点的前面添加我们的虚拟头结点,用一个指针去操作然后用虚拟头结点固定我们要返回的结点,当我们的指针的下一位不为空我们就不断循环我们指针指向下一个的值等于cur我们就对下一个元数进行删除将中间结点删除

第二题 206. 反转链表

题目:

题目

题目分析:

我们要进行链表的反转我们要用上双指针,其实这个可以说是对双指针的考核,无论是之前的滑动窗口还是KMP都是对指针的考核,我们要对双指针确定的区间进行判断,区间的范围要掌握,第一章的数组本质是对双指针和区间范围的考核,我们要定义区间的范围去使用同一遍历规则去进行循环要不然可能回出现各种问题。

这个是双指针版本代码:
​​​​
代码
上面的注释希望大家思考下然后写出递归版本代码

下面我给出递归版本代码:

在这里插入图片描述
大家可以常考一下好了下面就将来今天的重点了!!!

第三题 707. 设计链表,

题目:

是真的简单就是实现复杂

在这里插入图片描述

思路分析:

我也不废话了直接放代码

class MyLinkedList {
public://初始化链表MyLinkedList() {this->size = 0;this->head=new ListNode(0);//这个是虚拟结点}//获取到第index个结点数值,如果index是非法的数值直接返回-1,注意index是从0开始int get(int index) {if(index<0||index>=size){//判断下标是否合法如果不合法返回-1return -1;//什么是合法就是判断的取的值是否在区间内}ListNode*cur = head;//头结点for(int i=0;i<=index;i++){//不断循环到index的结点cur = cur->next;}return cur->val;//返回index下面的值}void addAtHead(int val) {addAtIndex(0,val);//既然都是增加结点那么调用我们增加结点的函数就可以}void addAtTail(int val) {addAtIndex(size,val);//同理}//增加结点//如果index个节点之前插入新节点,那么新插入的节点为链表的新头节点//如果index等于链表的长度,则说明是新插入的节点为链表的尾结点//如果index大于链表的长度,则返回为空void addAtIndex(int index, int val) {if(index>size){//如果索引值越界那么我们直接返回空即可return ;}index = max(0,index); //我们的下标在取最大值防止我们的大小是负数,我们索引也是负数的情况size++;//因为我们要增加一个结点所以我们就要将我们的长度加1ListNode*pred = head;//创建一个一个指针去移动for(int i=0;i<index;i++){pred = pred->next;//移动到当前我们索引的位置的前一位}ListNode*toAdd = new ListNode(val);//然后我们又创建了一个结点去将这给结点增加到我们的要增加的位置toAdd->next = pred->next;//我们这个新结点的指针指向下一位是我们当前要插入结点位置的指针指向下一位,pred->next = toAdd;//然后将我们索引的位置的前一位指向我们的插入结点}void deleteAtIndex(int index) {//删除结点if(index<0||index>=size){return ;}size--;//因为我们删除了元素所以我们的长度要减ListNode*pred = head;//我们创建指针去指向我们的结点for(int i=0;i<index;i++){//不断将我的结点移动到我们要删除元素的下一位然后退出循环pred = pred->next;}ListNode*p=pred->next;//这个p指向的就是我们要删除的结点pred->next = pred->next->next;//我们将结点的指向修改然后删除p指向的结点即可delete p;}private://定义一个私有属性int size;ListNode*head;
};

这个可不盖的代码比较复杂都是对链表的基础操作,反正我是要背的
下面我给出c语言版本代码供大家参考:

class MyLinkedList {
public:MyLinkedList() {this->size = 0;this->head=new ListNode(0);}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;}void addAtHead(int val) {addAtIndex(0,val);}void addAtTail(int val) {addAtIndex(size,val);}void addAtIndex(int index, int val) {if(index>size){return ;}index = max(0,index);size++;ListNode*pred = head;for(int i=0;i<index;i++){pred = pred->next;}ListNode*toAdd = new ListNode(val);toAdd->next = pred->next;pred->next = toAdd;}void deleteAtIndex(int index) {if(index<0||index>=size){return ;}size--;ListNode*pred = head;for(int i=0;i<index;i++){pred = pred->next;}ListNode*p=pred->next;pred->next = pred->next->next;delete p;}private:int size;ListNode*head;
};

好了如果有什么不懂的在评论区留言,会解答的。
今天的分享到这里,如果喜欢这篇文章可以点个赞关注持续更新中…

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

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

相关文章

MySQL事务与MVCC详解

前置概念之事务 在开始MVCC的讨论之前&#xff0c;我们必须了解一些关于事务的概念。 什么是事务 现在我们开发的一个功能需要进行操作多张表&#xff0c;假如我们遇到以下几种情况: 某个逻辑报错数据库连接中断某台服务器突然宕机… 这时候我们数据库执行的操作可能才到一…

理解Socket

前言 我在去年就学习过Java中Socket的使用&#xff0c;但对于Socket的理解一直都是迷迷糊糊的。看了网上很多关于Socket的介绍&#xff0c;看完还是不太理解到底什么是Socket&#xff0c;还是很迷。直到最近在学习计算机网络&#xff0c;我才对Socket有了一个更深地理解。之前一…

Chapter 7 - 3. Congestion Management in Ethernet Storage Networks以太网存储网络的拥塞管理

Pause Threshold for Long Distance Links长途链路的暂停阈值 This section uses the following basic concepts: 本节使用以下基本概念: Bit Time (BT): It is the time taken to transmit one bit. It is the reciprocal of the bit rate. For example, BT of a 10 GbE po…

Axure中动态面板使用及轮播图多种登录方式左侧导航栏之案列

&#x1f3ac; 艳艳耶✌️&#xff1a;个人主页 &#x1f525; 个人专栏 &#xff1a;《产品经理如何画泳道图&流程图》 ⛺️ 越努力 &#xff0c;越幸运 目录 一、轮播图简介 1、什么是轮播图 2、轮播图有什么作用 3、轮播图有什么特点 4、轮播图适应范围 5、…

使用opencv的Canny算子实现图像边缘检测

1 边缘检测介绍 图像边缘检测技术是图像处理和计算机视觉等领域最基本的问题&#xff0c;也是经典的技术难题之一。如何快速、精确地提取图像边缘信息&#xff0c;一直是国内外的研究热点&#xff0c;同时边缘的检测也是图像处理中的一个难题。早期的经典算法包括边缘算子方法…

Android--UML类图使用详解

明敕星驰封宝剑&#xff0c;辞君一夜取楼兰 一&#xff0c;定义 类图(Class diagram)是显示了模型的静态结构&#xff0c;特别是模型中存在的类、类的内部结构以及它们与其他类的关系等。类图不显示暂时性的信息。类图是面向对象建模的主要组成部分。它既用于应用程序的系统分…

Open3D颜色变换

open3D的颜色是用小数表示的&#xff0c;和我们正常0-255不一样。换算也很简单 例如 红色RGB(230,26,26) 转换为 Open3D红色是RGB(0.9,0.1,0.1) 计算机颜色255*open3D颜色值 Open3D颜色值计算机颜色值/255 mesh_box.paint_uniform_color([0.9, 0.1, 0.1]) Open3D颜色值 value/…

[CC13X0] XDS100V3连接报错:Make sure your device is unlocked.

用XDS100V3给CC1310下载程序时&#xff0c;发现如下连接错误&#xff1a; An error occurred while hard opening the controller. -----[An error has occurred and this utility has aborted]-------------------- This error is generated by TIs USCIF driver or utilities…

Java8实战 - 行为参数化传递代码

背景&#xff1a; 根据《java8实战》把第二章简单概括一下。 在软件工程中&#xff0c;一个最重要的问题是&#xff0c;用户的需求会一直变化&#xff0c;如何应对不断变化的需求&#xff0c;并且把工作量降到最低是需要考虑的&#xff0c;而行为参数化就是一个处理频繁变更需…

飞天使-docker知识点8-docker的资源限制

文章目录 容器资源限制示例 容器资源限制 Docker提供了多种资源限制的方式&#xff0c;可以根据应用程序的需求和系统资源的可用性进行选择。以下是一些常见的Docker资源限制及其使用情况&#xff1a;CPU限制&#xff1a;通过设置CPU的配额&#xff08;quota&#xff09;和周期…

微服务保护--熔断降级

1.熔断降级介绍 熔断降级是解决雪崩问题的重要手段。其思路是由断路器统计服务调用的异常比例、慢请求比例&#xff0c;如果超出阈值则会熔断该服务。即拦截访问该服务的一切请求&#xff1b;而当服务恢复时&#xff0c;断路器会放行访问该服务的请求。 断路器控制熔断和放行…

el-date-picker 选择一个或多个日期

el-date-picker可选择多个日期 type“dates” 加个s即可 <div><span>el-date-picker选择多个日期</span><el-date-pickertype"dates"v-model"dateList"placeholder"选择一个或多个日期"></el-date-picker></di…