L30.【LeetCode笔记】设计链表

server/2025/2/1 7:24:42/

1.题目

707. 设计链表 - 力扣(LeetCode)

你可以选择使用单链表或者双链表,设计并实现自己的链表

链表中的节点应该具备两个属性:valnextval 是当前节点的值,next 是指向下一个节点的指针/引用。

如果是双向链表,则还需要属性 prev 以指示链表中的上一个节点。假设链表中的所有节点下标从 0 开始。

实现 MyLinkedList 类:

  • MyLinkedList() 初始化 MyLinkedList 对象。
  • int get(int index) 获取链表中下标为 index 的节点的值。如果下标无效,则返回 -1
  • void addAtHead(int val) 将一个值为 val 的节点插入到链表中第一个元素之前。在插入完成后,新节点会成为链表的第一个节点。
  • void addAtTail(int val) 将一个值为 val 的节点追加到链表中作为链表的最后一个元素。
  • void addAtIndex(int index, int val) 将一个值为 val 的节点插入到链表中下标为 index 的节点之前。如果 index 等于链表的长度,那么该节点会被追加到链表的末尾。如果 index 比长度更大,该节点将 不会插入链表中。
  • void deleteAtIndex(int index) 如果下标有效,则删除链表中下标为 index 的节点。

示例:

输入
["MyLinkedList", "addAtHead", "addAtTail", "addAtIndex", "get", "deleteAtIndex", "get"]
[[], [1], [3], [1, 2], [1], [1], [1]]
输出
[null, null, null, null, 2, null, 3]解释
MyLinkedList myLinkedList = new MyLinkedList();
myLinkedList.addAtHead(1);
myLinkedList.addAtTail(3);
myLinkedList.addAtIndex(1, 2);    // 链表变为 1->2->3
myLinkedList.get(1);              // 返回 2
myLinkedList.deleteAtIndex(1);    // 现在,链表变为 1->3
myLinkedList.get(1);              // 返回 3

提示:

  • 0 <= index, val <= 1000
  • 请不要使用内置的 LinkedList 库。
  • 调用 getaddAtHeadaddAtTailaddAtIndexdeleteAtIndex 的次数不超过 2000

2.代码

直接套用+修改C26.【C++ Cont】动态内存管理和面向对象的方式实现链文章的代码

struct Node
{int val;struct Node* next;
};class MyLinkedList 
{
public:Node* phead;Node* ptail;int length;Node* BuySLTNode(int x)//新建节点{Node* newnode = new Node;newnode->val = x;newnode->next = nullptr;return newnode;}MyLinkedList()//构造函数,自动调用{phead = nullptr;ptail = nullptr;length = 0;}int get(int index){if (length == 0 || index >= length)return -1;int tmp = 0;Node* cur = phead;while (tmp != index){cur = cur->next;tmp++;}return cur->val;}void addAtHead(int val){Node* newnode = BuySLTNode(val);if (phead == nullptr){phead = ptail = newnode;}else{newnode->next = phead;phead = newnode;//不用改动ptail}length++;}void addAtTail(int val){Node* newnode = BuySLTNode(val);if (phead == nullptr){ptail = phead = newnode;//如果是第一次插入需要同时更新首尾指针}else{ptail->next = newnode;ptail = ptail->next;}length++;}void addAtIndex(int index, int val){if (index > length)return;if (index == length){addAtTail(val);return;}if (index == 0){addAtHead(val);return;}Node* newnode = BuySLTNode(val);Node* cur = phead;int tmp = 0;while (tmp < index - 1){cur = cur->next;tmp++;}newnode->next = cur->next;cur->next = newnode;length++;}void SLTPopBack()//尾删节点{if (phead == nullptr){return;}Node* tmp = phead;if (phead->next == nullptr){delete phead;ptail = phead = nullptr;//删除最后一个节点,注意将首尾指针都置为空length--;return;}while (tmp->next != ptail)//寻找尾节点前面的节点{tmp = tmp->next;}delete ptail;ptail = tmp;ptail->next = nullptr;tmp = nullptr;length--;}void SLTPopFront()//头删节点{if (phead == nullptr){return;}if (phead->next == nullptr){ptail = nullptr;//链表只剩一个节点,ptail要手动置空}Node* tmp = phead;phead = tmp->next;delete tmp;tmp = nullptr;length--;}void deleteAtIndex(int index){if (index >= length || length == 0)return;if (index == length - 1){SLTPopBack();return;}if (index == 0){SLTPopFront();return;}Node* cur = phead;int tmp = 0;while (tmp < index - 1)//index-1>0{cur = cur->next;tmp++;}Node* indexnode = cur->next;cur->next = indexnode->next;delete indexnode;indexnode = nullptr;length--;}
};

注意点:

1.每一种情况返回前思考需不需要length++或者length--

★以SLTPopBack为例,有两个地方需要length--!!!(此处debug 1h 才看出来问题= =)

2.几个特殊情况的处理

get:链表长为0或者index>=length的,一律返回-1

addAtIndex:index>length不作处理,index==length按题意理解为尾插,index==0为头插

deleteAtIndex:链表长为0或者index>=length的,一律不处理;index == length - 1尾删;index == 0头删

3.提交结果


http://www.ppmy.cn/server/164003.html

相关文章

程序诗篇里的灵动笔触:指针绘就数据的梦幻蓝图<2>

大家好啊&#xff0c;我是小象٩(๑ω๑)۶ 我的博客&#xff1a;Xiao Xiangζั͡ޓއއ 很高兴见到大家&#xff0c;希望能够和大家一起交流学习&#xff0c;共同进步。 今天我们来学习const修饰指针&#xff0c;包括const修饰变量&#xff0c;const修饰指针变量&#xff1b…

特权模式docker逃逸

目录 1.环境 2.上线哥斯拉 3.特权模式逃逸 1.判断是否为docker环境 2.判断是否为特权模式 3.挂载宿主机磁盘到docker 4.计划任务反弹shell 1.环境 ubuntu部署一个存在CVE-2017-12615的docker: (ip:192.168.117.147) kali(ip:192.168.117.128) 哥斯拉 2.上线哥斯拉…

Redis入门概述

1.1、Redis是什么 Redis&#xff1a;官网 高性能带有数据结构的Key-Value内存数据库 Remote Dictionary Server&#xff08;远程字典服务器&#xff09;是完全开源的&#xff0c;使用ANSIC语言编写遵守BSD协议&#xff0c;例如String、Hash、List、Set、SortedSet等等。数据…

springboot集成钉钉,发送钉钉日报

目录 1.说明 2.示例 3.总结 1.说明 学习地图 - 钉钉开放平台 在钉钉开放文档中可以查看有关日志相关的api&#xff0c;主要用到以下几个api&#xff1a; ①获取模板详情 ②获取用户发送日志的概要信息 ③获取日志接收人员列表 ④创建日志 发送日志时需要根据模板规定日志…

PyQt5之QtDesigner的若干配置和使用

1.描述 QtDesigner是一个可视化工具&#xff0c;可以通过该工具设计页面 2.简单使用 1.下载PyQt5-tools pip install pyqt5-tools 2.打开designer.exe文件 我采用的是虚拟环境&#xff0c;该文件位于C:\Users\24715\anaconda3\envs\pyqt\Lib\site-packages\qt5_applicatio…

17.2 图形绘制3

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 17.2.4 Pen类 Pen类用于绘制线段和曲线。 Pen构造函数常用重载版本&#xff1a; Pen(Brush)&#xff1a;使用指定的Brush初始化P…

AI 浪潮席卷中国年,开启科技新春新纪元

在这博主提前祝大家蛇年快乐呀&#xff01;&#xff01;&#xff01; 随着人工智能&#xff08;AI&#xff09;技术的飞速发展&#xff0c;其影响力已经渗透到社会生活的方方面面。在中国传统节日 —— 春节期间&#xff0c;AI 技术也展现出了巨大的潜力&#xff0c;为中国年带…

深入学习华为IPD流程之华为-PDT经理角色认知培训教材

本文介绍了PDT经理的角色认知,包括其在IPD体系中的位置、基本角色定位、关键管理活动、能力模型和评估方法以及培养路径。文章指出PDT经理是重量级产品开发团队的管理者,负责产品的商业成功和跨功能部门合作,通过绩效管理加强团队凝聚力,对商业结果负责。 重点内容: 1. …