算法学习——LeetCode力扣链表篇1

算法学习——LeetCode力扣链表篇1

在这里插入图片描述

203. 移除链表元素

203. 移除链表元素 - 力扣(LeetCode)

描述

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。

示例

示例 1:
在这里插入图片描述

输入:head = [1,2,6,3,4,5,6], val = 6
输出:[1,2,3,4,5]

示例 2:

输入:head = [], val = 1
输出:[]

示例 3:

输入:head = [7,7,7,7], val = 7
输出:[]

提示

  1. 列表中的节点数目在范围 [0, 104] 内
  2. 1 <= Node.val <= 50
  3. 0 <= val <= 50

代码解析

自己写版本

容易出现操作空指针,要为对应的特殊情况做处理
直接在原本的链表上做处理。
分为两种情况

  • 删除链表头
  • 删除非表头
class Solution {
public:
    ListNode* removeElements(ListNode* head, int val) {

       
        if (head == NULL)return NULL;

        ListNode* temp, * tempnext, * Head = head, * dele_val;

        while (Head->val == val)
        {
            dele_val = Head;
            if (Head->next != nullptr)Head = Head->next;
            else return NULL;
            delete dele_val;
        }
        temp = Head;
        tempnext = temp->next;
        if (tempnext == nullptr)return Head;
        while (tempnext->next != nullptr)
        {

            if (tempnext->val == val)
            {
                temp->next = tempnext->next;
                dele_val = tempnext;
                delete dele_val;
                tempnext = temp->next;
            }
            else
            {
                temp = temp->next;
                tempnext = temp->next;

            }
        }


        if (tempnext->val == val)
        {
            temp->next = nullptr;
            delete tempnext;
        }
        return Head;
    
    }
};

虚拟头节点

主动在链表之前加一个虚拟头,这样将删除头节点和删除其他节点合并成一种类型

/**
 * 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 *duny_head = new ListNode(0,head);
        ListNode *cur = duny_head;

        while(cur->next != nullptr)
        {
            if(cur->next->val == val) 
            {
                ListNode *tmp = cur->next;
                cur->next = cur->next->next;
                delete tmp;
            }else
                cur = cur->next;
        }
        ListNode *result = duny_head->next;
        delete duny_head;
        return result;
    }
};

707. 设计链表

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

描述

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

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

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

实现 MyLinkedList 类:

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

提示

  1. 0 <= index, val <= 1000
  2. 请不要使用内置的 LinkedList 库。
  3. 调用 get、addAtHead、addAtTail、addAtIndex 和 deleteAtIndex 的次数不超过 2000 。

代码解析

class MyLinkedList {
public:
    struct Linknode
    {
        int val;
        Linknode *next;
        Linknode():val(0),next(nullptr){}
        Linknode(int x):val(x),next(nullptr){}
        Linknode(int x , Linknode* ptr):val(0),next(ptr){}
    };
    MyLinkedList() {
        _dummy_head = new Linknode(0);
        _size = 0;
    }
    
    int get(int index) {
        if(index > _size-1 || index < 0) return -1;
        Linknode *cur = _dummy_head->next;
        while(index)
        {
            cur = cur->next;
            index--;
        }
        return cur->val;
    }
    
    void addAtHead(int val) {
        Linknode *tmp = new Linknode(val);
        tmp->next = _dummy_head->next;
        _dummy_head->next = tmp;
        _size++;
    }
    
    void addAtTail(int val) {
        Linknode *tmp = new Linknode(val);
        Linknode *cur = _dummy_head;
        while(cur->next != nullptr)
            cur = cur->next;
        cur->next = tmp;
        _size++;
    }
    
    void addAtIndex(int index, int val) {
        if(index > _size) return;
        else if(index <= 0) addAtHead(val);
        else if(index == _size) addAtTail(val);
        else
        {
            Linknode *tmp = new Linknode(val);
            Linknode *cur = _dummy_head;
            while(index)
            {
                cur = cur->next;
                index--;
            }
            tmp->next = cur->next;
            cur->next = tmp;
            _size++;
        }
    }
    
    void deleteAtIndex(int index) {
        if(index > _size-1 || index<0 ) return;
        Linknode *cur = _dummy_head;

        while(index)
        {
            cur = cur->next;
            index--;
        }
        Linknode *tmp = cur->next;
        cur->next = cur->next->next;
        delete tmp;
        _size--;

    }
private:
    Linknode *_dummy_head;
    int _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);
 */

206. 反转链表

206. 反转链表 - 力扣(LeetCode)

描述

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例

示例 1:

在这里插入图片描述

输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

示例 2:

在这里插入图片描述

输入:head = [1,2]
输出:[2,1]

示例 3:

输入:head = []
输出:[]

提示

链表中节点的数目范围是 [0, 5000]
-5000 <= Node.val <= 5000

进阶

链表可以选用迭代或递归方式完成反转。你能否用两种方法解决这道题?

代码解析

自己写版本

处理分四种类型

  1. 链表为空
  2. 链表长度为1
  3. 链表长度为2
  4. 链表大于等于三
#include <iostream>
#include <vector>
#include<algorithm> 

using namespace std;




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) {

        ListNode *cur ;
        ListNode* temp1, * temp2 ;

        if(head == nullptr || head->next == nullptr) return head;//处理链表为空或者长度为1

        if(head->next->next == nullptr)//处理链表长度为2
        {
            temp1 = head;
            temp2 = head->next;

            temp2->next = temp1;
            temp1->next = nullptr;
            return temp2;
        }
		//处理链表长度为3及其以上
        temp1 = head;
        cur = temp1->next;
        temp2 = cur->next;

  
        while (temp2 != nullptr)
        {
            cur->next = temp1;
            if (temp1 == head)
            {
                temp1->next = nullptr;
                temp1 = cur;
            }     
            else temp1 = cur;
            cur = temp2;
            if(cur->next != nullptr) temp2 = cur->next;//检查链表是否到底
            else
            {
                cur->next = temp1;
                break;
            }
        }
        

        return cur;

    }
};



int main()
{
    vector<int> head = { 1,2,3,4,5,6 };

    ListNode* head_test = new ListNode(0);
    ListNode* test  , *cur = head_test;
    Solution  a;

    for (int i = 0; i < head.size(); i++)
    {
       
       ListNode* temp = new ListNode(head[i]);
       cur->next = temp;
       cur = cur->next;
      
    }
    cur->next = nullptr;

    cur = head_test;
    cout << "cur list" << endl;
    while (cur->next != nullptr)
    {
        cout << cur->val << ' ';
        cur = cur->next;
    }
    cout << cur->val << endl;


    test = a.reverseList(head_test->next);

    while (test->next != nullptr)
    {
        cout << test->val << ' ';
        test = test->next;
    }
    cout << test->val << ' ';
	return 0;

}

双指针法
class Solution {
public:
    ListNode* reverseList(ListNode* head) {

        ListNode *cur ;
        ListNode* temp1, * temp2 ;

        cur = head;
        temp1 = nullptr;
       
        while (cur)
        {
            temp2 = cur->next;
            cur->next = temp1;

            temp1 = cur;
            cur = temp2;
        }
        return temp1;
    }
};

递归法
class Solution {
public:
    ListNode* reverse(ListNode *pre , ListNode * cur) {

        if (cur == nullptr)return pre;

        ListNode* temp = cur->next;
        cur->next = pre;
        return reverse(cur , temp);
    }

    ListNode* reverseList(ListNode* head) {

        return reverse(nullptr , head);
    }
};

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

thinkphp数据批量提交(群发消息)

<form id="edit-form" class="form-horizontal" role="form" data-toggle<

Verilog实现2进制码与BCD码的互相转换

1、什么是BCD码&#xff1f; BCD码是一种2进制的数字编码形式&#xff0c;用4位2进制数来表示1位10进制中的0~9这10个数。这种编码技术&#xff0c;最常用于会计系统的设计里&#xff0c;因为会计制度经常需要对很长的数字做准确的计算。相对于一般的浮点式记数法&#xff0c;…

Camera2+OpenGL ES+MediaCodec+AudioRecord实现录制音视频写入H264 SEI数据

记录一下学习过程&#xff0c;得到一个需求是基于Camera2OpenGL ESMediaCodecAudioRecord实现录制音视频。 需求&#xff1a; 在每一帧视频数据中&#xff0c;写入SEI额外数据&#xff0c;方便后期解码时获得每一帧中的自定义数据。点击录制功能后&#xff0c;录制的是前N秒至…

RCS系统之:显示AGV预测路线

在AGV做业务过程中&#xff0c;常会看到AGV一直停在哪里&#xff0c;没有任何动作。所以显示AGV马上要行进的路线非常有必要。 好处有&#xff1a; AGV是否有任务&#xff0c;AGV是否已经规划出路线&#xff1b;AGV马上要行进的路线 那具体要如何实现呢&#xff1f;有兴趣的可…

ONLYOFFICE:一站式办公,探索高效办公新境界

写在前面ONLYOFFICE 介绍ONLYOFFICE 有哪些优势ONLYOFFICE 文档 8.0 发布如何体验 ONLYOFFICEONLYOFFICE 文档部分页面截图 写在前面 在当今这样一个数字化时代&#xff0c;办公软件已经成为我们日常工作中不可或缺的一部分&#xff0c;熟练使用 Office、WPS、腾讯文档、金山文…

如何在Mac上允许主流浏览器使用弹出式窗口?这里有详细步骤

这篇文章教你如何关闭流行的Mac浏览器上的弹出窗口阻止程序,包括Safari、Chrome和Firefox。它还探讨了你可能希望这样做的原因及其影响。 如何在Mac上允许Safari使用弹出窗口 如果你经常在Mac上使用Safari,你会注意到默认情况下弹出窗口阻止程序是打开的。有时,这并不方便…

[office] 教你实现Excel中工作表重命名的诀窍 #知识分享#职场发展#其他

教你实现Excel中工作表重命名的诀窍 在Excel中要实现工作表的重命名其实不是难事&#xff0c;重在你要掌握技巧。一些初学者&#xff0c;可能还不是特别的懂。今天&#xff0c;小编就要一步步来教一下大家了。有两种方法&#xff0c;大家学好了。 方法一、打开excel表格&#x…

YOLOv8改进 | 检测头篇 | 重参数化检测头RepHead解决困难样本检测(全网独家首发)

一、本文介绍 本文给大家带来的改进机制是RepHead,该检测头为我独家全网首发,该检测头由重参数化模块组成,加大对于特征学习的能力,却可以不增加GFLOPs(仅仅略微提升)从而不影响模型的推理速度和性能,保持较高的FPS能力,牺牲了少量GFLOPs的情况下确提高了模型的特征提…

进程和线程的区别详解

&#x1f3a5; 个人主页&#xff1a;Dikz12&#x1f4d5;格言&#xff1a;那些在暗处执拗生长的花&#xff0c;终有一日会馥郁传香欢迎大家&#x1f44d;点赞✍评论⭐收藏 目录 进程 进程在系统中是如何管理的 进一步认识PCB 线程 能否一直增加线程数目来提高效率 进程和线程…

极狐GitLab 与钉钉的集成实践

DingTalk OAuth 2.0 OmniAuth provider * 引入于 14.5 版本。 您可以使用您的钉钉账号登录极狐GitLab。 登录钉钉开放平台&#xff0c;创建应用。钉钉会生成一个客户端 ID 和密钥供您使用。 登录钉钉开放平台。 在顶部栏上&#xff0c;选择 应用程序开发 > 企业内部开发&am…

数据挖掘实战-基于决策树算法构建北京市空气质量预测模型

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

看论文利器:paperswithcode

paperswithcode&#xff0c;从名字就可以看出来&#xff0c;有源代码的paper。 写论文&#xff0c;很关键的就是能够复现论文内容。 这个网站提供了“论文代码”的参考文献。 以【图像加密】领域为例&#xff0c;搜索一下&#xff1a; 图像分割&#xff1a; 除了论文&#x…

2024.2.5日总结(小程序开发2)

小程序的宿主环境 宿主环境 宿主环境指的是程序运行所必须的依赖环境。 Android系统和iOS系统是两个不同的宿主环境。安卓版的微信App不能再iOS环境下运行。Android是安卓软件的宿主环境&#xff0c;脱离了宿主环境的软件是没有意义的。 小程序的宿主环境 手机微信是小程序…

Uibot (RPA设计软件)智能识别信息+微信群发助手(升级版)———课后练习1

微信群发助手机器人的小项目友友们可以参考小北的课前材料二博客~ (本博客中会有部分课程ppt截屏,如有侵权请及请及时与小北我取得联系~&#xff09; 紧接着小北的前两篇博客&#xff0c;友友们我们即将开展新课的学习~RPA 培训前期准备指南——安装Uibot(RPA设计软件&#x…

jmeter-问题一:关于线程组,线程数,用户数详解

文章目录 jmeter参数介绍1.线程数2.准备时长(Ramp-up)3.循环次数4.same user on each iteratio5.调度器 场景一&#xff1a;当你的线程组中线程数为1,循环为1场景二&#xff1a;当你的线程组中线程数为2&#xff0c;循环为1场景三&#xff1a;当你的线程组中线程数为1&#xff…

Javascript | 打印菱形

Javascript打印菱形&#xff0c;在校大学生可以拿来糊弄作业&#xff08;笑&#xff09; var str ; for (var i 1; i < 9; i) {if (i < 5) {for (var k1 1; k1 < 5 - i; k1) {str ;}} else {for (var k2 1; k2 < i - 5; k2) {str ;}}if (i < 5) {for (…

升级Oracle 单实例数据库19.3到19.22

需求 我的Oracle Database Vagrant Box初始版本为19.3&#xff0c;需要升级到最新的RU&#xff0c;当前为19.22。 以下操作时间为为2024年2月5日。 补丁下载 补丁下载文档参见MOS文档&#xff1a;Primary Note for Database Proactive Patch Program (Doc ID 888.1)。 补丁…

大模型|基础_word2vec

文章目录 Word2Vec词袋模型CBOW Continuous Bag-of-WordsContinuous Skip-Gram存在的问题解决方案 其他技巧 Word2Vec 将词转化为向量后&#xff0c;会发现king和queen的差别与man和woman的差别是类似的&#xff0c;而在几何空间上&#xff0c;这样的差别将会以平行的关系进行表…

【算法与数据结构】718、1143、1035、392、115、LeetCode最长重复子数组+最长公共子序列+不相交的线+判断子序列+不同的子序列

文章目录 一、718、最长重复子数组二、1143、最长公共子序列三、1035、不相交的线四、392、判断子序列五、115、不同的子序列六、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、718、最长重复子数组 思路分析&#xff1…

电阻一文搞懂!

1.品牌 厚声、风华&#xff0c;三星、罗姆、松下、KOA 2.分类 插件 碳膜电阻&#xff1a;精度-5 J 是在高阻&#xff0c;高压和高温应用中 属负温度系数电阻 金属膜&#xff1a;-1 F 薄膜电阻和厚膜电阻的区别&#xff1a;薄膜电阻和厚膜电阻区别&#xff0c;了解即可…