代码随想录day3 203.移除列表元素 707.设计链表 206.反转链表

2023-12-03 00:52

本文主要是介绍代码随想录day3 203.移除列表元素 707.设计链表 206.反转链表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数组是在内存中是连续分布的,但是链表在内存中可不是连续分布的。

双链表

单链表中的指针域只能指向节点的下一个节点。

双链表:每一个节点有两个指针域,一个指向下一个节点,一个指向上一个节点。

双链表 既可以向前查询也可以向后查询。

问题:约瑟夫环是什么?循环列表为什么能解决约瑟夫环的问题?

链表的代码:

// 单链表
struct ListNode {int val;  // 节点上存储的元素ListNode *next;  // 指向下一个节点的指针ListNode(int x) : val(x), next(NULL) {}  // 节点的构造函数
};

删除链表节点,对于c++需要释放内存,其他语言例如Java、Python,就有自己的内存回收机制,就不用自己手动释放了。

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* removeElements(ListNode* head, int val) {ListNode* virt=new ListNode(0,head);  //要加newvirt->val=0;virt->next=head;ListNode* tmp;tmp=virt;while(tmp->next!=NULL){if(tmp->next->val==val){ListNode* tmp1= tmp->next;// tmp->next =tmp1->next;// tmp1->next=NULL;tmp->next=tmp->next->next;delete tmp1;}else{tmp=tmp->next;}}head=virt->next;delete virt;return head; //必须从头节点返回才行,直接选取head节点开始返回不行}
};

参考了题解才改对的,就是主要是本来没有 head=virt->next;        delete virt; 就直接返回head,可能因为有前他指针指向head,不能直接返回。要->next得到虚拟节点的下一个。

另外,是用ListNode* virt=new ListNode(0,head); ,也就是用new什么来声明一个指针。

delete tmp1;就是指针节点。

707.设计链表  

链表操作的两种方式:

  1. 直接使用原来的链表来进行操作。
  2. 设置一个虚拟头结点在进行操作。

这道题需要自己定义链表节点结构体

MyLinkedList()是初始化函数

class MyLinkedList {
public:struct linkedNode{int val;linkedNode* next;linkedNode(int val):val(val),next(nullptr){}};MyLinkedList() {// int num=0;// linkedNode * head=new linkedNode(0);_num=0;_head=new linkedNode(0);}int get(int index) {if(_num<=index) return -1;linkedNode * tmp=_head;int tmpN=-1;while(tmp->next!=NULL){tmp=tmp->next;tmpN++;if(tmpN==index){return tmp->val;}}return -1;}void addAtHead(int val) {// linkedNode * tmp=head;linkedNode * newT=new linkedNode(val);newT->next=_head->next;_head->next=newT;_num++;}void addAtTail(int val) {linkedNode * newT=new linkedNode(val);linkedNode * tmp=_head;//int tmpN=-1;while(tmp->next!=NULL){tmp=tmp->next;}_num++;tmp->next=newT;}void addAtIndex(int index, int val) {if(index>_num) return ;linkedNode * newT=new linkedNode(val);linkedNode * tmp=_head;int tmpN=-1;while(tmp->next!=NULL){tmpN++;if(tmpN==index){newT->next=tmp->next;_num++;tmp->next=newT;return;// return tmp->val;}tmp=tmp->next;}if((tmpN+1)==index){tmp->next=newT;_num++;}return ;// tmp->next=newT;}void deleteAtIndex(int index) {linkedNode * tmp=_head;int tmpN=-1;while(tmp->next!=NULL){tmpN++;if(tmpN==index){linkedNode * tmpN=tmp->next;tmp->next=tmp->next->next;delete tmpN;_num--;return;// return tmp->val;}tmp=tmp->next;}}private:int _num;linkedNode * _head;
};/*** 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);*/

这道题需要自己再定义一个linkedNode结构体,一开始我不知道linkednode是不是应该放在mylinkedlist下面,mylinkedlist是初始化函数,所以是放在public下。而初始化函数是赋值初值的,在private:下面可以声明函数的私有成员变量,而不是在初始化函数声明。看了眼题解的写法才写出来,主要是忘记了c++的语法。

要注意index小于0时特判不合法。下面代码是复制过来的,为了提示自己tmp最好赋值个nullptr。

 void deleteAtIndex(int index) {if (index >= _size || index < 0) {return;}LinkedNode* cur = _dummyHead;while(index--) {cur = cur ->next;}LinkedNode* tmp = cur->next;cur->next = cur->next->next;delete tmp;//delete命令指示释放了tmp指针原本所指的那部分内存,//被delete后的指针tmp的值(地址)并非就是NULL,而是随机值。也就是被delete后,//如果不再加上一句tmp=nullptr,tmp会成为乱指的野指针//如果之后的程序不小心使用了tmp,会指向难以预想的内存空间tmp=nullptr;_size--;}

 

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* reverseList(ListNode* head) {if(head==nullptr) return nullptr;ListNode * tmp =head;ListNode * tmpN;tmpN= tmp->next;ListNode* node;while(tmpN!=NULL){node=tmpN;tmpN=tmpN->next;node->next=tmp;tmp=node;// tmp=tmp->next;}head->next=NULL;return tmp;}
};

一遍ac,注意特判空列表的情况。比如有三个节点,第二个节点反过来要指向第一个,那原本遍历数组需要的第二个节点指向的下一个也要用其他指针指向保留。其实套用在具体例子下就比较好写了。相当于一个三个数的滑窗,每次窗口内要处理前两个数为后一个数指向前一个数。

        其实就是双指针法,题解的方法是:

class Solution {
public:ListNode* reverseList(ListNode* head) {ListNode* temp; // 保存cur的下一个节点ListNode* cur = head;ListNode* pre = NULL;while(cur) {temp = cur->next;  // 保存一下 cur的下一个节点,因为接下来要改变cur->nextcur->next = pre; // 翻转操作// 更新pre 和 cur指针pre = cur;cur = temp;}return pre;}
};

这篇关于代码随想录day3 203.移除列表元素 707.设计链表 206.反转链表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/447499

相关文章

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill

使用MapStruct实现Java对象映射的示例代码

《使用MapStruct实现Java对象映射的示例代码》本文主要介绍了使用MapStruct实现Java对象映射的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、什么是 MapStruct?二、实战演练:三步集成 MapStruct第一步:添加 Mave