代码随想录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

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

csu1329(双向链表)

题意:给n个盒子,编号为1到n,四个操作:1、将x盒子移到y的左边;2、将x盒子移到y的右边;3、交换x和y盒子的位置;4、将所有的盒子反过来放。 思路分析:用双向链表解决。每个操作的时间复杂度为O(1),用数组来模拟链表,下面的代码是参考刘老师的标程写的。 代码如下: #include<iostream>#include<algorithm>#include<stdio.h>#

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

深入手撕链表

链表 分类概念单链表增尾插头插插入 删尾删头删删除 查完整实现带头不带头 双向链表初始化增尾插头插插入 删查完整代码 数组 分类 #mermaid-svg-qKD178fTiiaYeKjl {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

c++的初始化列表与const成员

初始化列表与const成员 const成员 使用const修饰的类、结构、联合的成员变量,在类对象创建完成前一定要初始化。 不能在构造函数中初始化const成员,因为执行构造函数时,类对象已经创建完成,只有类对象创建完成才能调用成员函数,构造函数虽然特殊但也是成员函数。 在定义const成员时进行初始化,该语法只有在C11语法标准下才支持。 初始化列表 在构造函数小括号后面,主要用于给