单链表经典例题

news2024/11/29 1:39:33

LeetCode题解

  • 移除链表元素
  • 反转链表
  • 合并两个有序链表

移除链表元素

题目描述:
在这里插入图片描述
➡️挑战链接⬅️、
分析:
该题是要求我们删除指定元素,那么我们就定义一个cur指针去遍历整个链表就好了,每当我们遇到cur->val==val;等于特定值的时候我们就释放掉该节点就可以了;
如果我们遇到的不是特定值,则直接将该节点摘下来,即可;
当然,既然摘下来了,就不能让这些节点,孤单着,我门内就得找一个“线”捡起链接起来;
最后返回新头就行了;
这里我们采取不带哨兵位的方法讲解一下:
在这里插入图片描述
代码实现:

struct ListNode* removeElements(struct ListNode* head, int val){
         struct ListNode*Newhead=NULL;
         struct ListNode*tail=NULL;
         struct ListNode*cur=head;
         struct ListNode*next=NULL;
         while(cur)
         {
             if(cur->val==val)
             {
                 next=cur->next;
                 free(cur);
                 cur=next;
             }
             else 
             {
                 if(tail==NULL)
                 {
                     next=cur->next;
                     Newhead=tail=cur;
                     tail->next=NULL;
                     cur=next;
                 }
                 else
                 {
                     next=cur->next;
                     tail->next=cur;
                     tail=cur;
                     tail->next=NULL;
                     cur=next;
                 }
             }
         }
         return Newhead;
}

在这里插入图片描述
时间复杂度:O(N)
空间复杂度:O(1)

如果采用带哨兵位的头节点的话,我们就不用考虑特殊情况,直接就能在tail尾部插入,代码自然也会简短一点;
代码实现:

struct ListNode* removeElements(struct ListNode* head, int val){
           struct ListNode*dummyhead=(struct ListNode*)malloc(sizeof(struct ListNode));
           struct ListNode*prev=dummyhead;
           dummyhead->next=head;
           struct ListNode*cur=head;
           while(cur)
           {
               if(cur->val!=val)
               {
                   prev=cur;
                   cur=cur->next;
               }
               else 
               {
                   struct ListNode*next=cur->next;
                   prev->next=next;
                   cur=next;
               }
           }
           struct ListNode*newHead=dummyhead->next;
           free(dummyhead);
           return newHead;
}

在这里插入图片描述

反转链表

题目描述:
在这里插入图片描述
➡️挑战链接⬅️
分析:
反转链表,我们可以遍历一遍单链表,然后将每个单链表利用尾插的方式实现,就能达到链表反转的结果了:
在这里插入图片描述
代码实现:

struct ListNode* reverseList(struct ListNode* head){
         struct ListNode*retHead=NULL;
         struct ListNode*cur=head;
         struct ListNode*next=NULL;
         while(cur)
         {
             next=cur->next;
             cur->next=retHead;
             retHead=cur;
             cur=next;
         }
         return retHead;
}

时间复杂度:O(N)
空间复杂度:O(1)

在这里插入图片描述

合并两个有序链表

题目描述:
在这里插入图片描述
➡️挑战链接⬅️
分析:
题目给了一个很好的条件,链表有序,那么我们就可以根据归并排序的思想,对于链表进行合并;
我们同时对于连个链表进行遍历,没遇到val值,比较小的节点,我们就把它采摘下来;同时完成对于采摘下来的节点进行重新链接;
我们采取不带哨兵位实现,带哨兵位读者可以自行研究一下😊😊😊)
在这里插入图片描述
代码实现:

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){    
            struct ListNode*Newhead=NULL;
            struct ListNode*tail=NULL;
            struct ListNode*l1=list1;
            struct ListNode*l2=list2;
            struct ListNode*next=NULL;
            while(l1&&l2)
            {
               if(l1->val>l2->val)
               {
                 next=l2->next;
                   if(tail==NULL)
                   {
                   Newhead=tail=l2;
                   }
                   else 
                   {
                       tail->next=l2;
                       tail=l2;
                   }
                   tail->next=NULL;
                       l2=next;
               }
               else
               {
                 next=l1->next;
                   if(tail==NULL)
                   {
                   Newhead=tail=l1;
                   }
                   else 
                   {
                       tail->next=l1;
                       tail=l1;
                   }
                   tail->next=NULL;
                       l1=next;
               }
            }
            if(l1)
              {
                  if(tail==NULL)
                  Newhead=l1;
                  else
                  tail->next=l1;
              }
            if(l2)
            {
                  if(tail==NULL)
                  Newhead=l2;
                  else
                  tail->next=l2;
              }
            return Newhead;
}

在这里插入图片描述
其实一道题需不需要带哨兵位来解决,主要还是看头节点有没有可能会被改变,如果有可能,我们就需要添加哨兵位的头节点来帮忙,这样我们就可以避免讨论很多的特殊情况;反之,我们就没比要构造哨兵位的头节点;

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【PTA-训练day3】L2-014 列车调度 + L1-009 N个数求和

目录 L2-014 列车调度 - 二分贪心 1、java版 - 运行超时 2、c版 L1-010 比较大小 - 10 L1-015 跟奥巴马一起画方块 - 15 L1-009 N个数求和 - 20 java 欧几里得求最大公约数gcd L2-014 列车调度 - 二分贪心 PTA | 程序设计类实验辅助教学平台 如果当前序号比火车队列末…

最流行的 6 款 Python 解释器

有人说:一个人从1岁活到80岁很平凡,但如果从80岁倒着活,那么一半以上的人都可能不凡。 生活没有捷径,我们踩过的坑都成为了生活的经验,这些经验越早知道,你要走的弯路就会越少。 Python 是最流行的编程语言…

双向长短期记忆网络(BiLSTM)详解

双向长短期记忆网络(BiLSTM)详解 一、前言 在学习BiLSTM之前,首先需要对RNN和LSTM有一定的了解,可以参考本人的博客:详细讲解RNNLSTMTree_LSTM(Tree-Long Short Term Memory)基于树状长短期记忆…

22、短信登录(隐藏用户的敏感信息)

短信登录(隐藏用户的敏感信息) 我们返回给前端的信息太多了 问题:为什么我们这里全返回了呢? 我们这里是直接从userHoler里获取用户后就直接返回。 所以我们冲userHoler里取出来的信息就是完整的。 2、userHoler从哪里来&#x…

RSA与AES加密

目录 一、非对称加密和RSA 1.非对称秘钥 2.RSA加密的核心 3.Python中实现RSA加密解密 二、HTTPS通信过程 三、对称加密和AES 1.AES简介 2.Python中实现AES加解密 一、非对称加密和RSA 1.非对称秘钥 https://blog.csdn.net/gao131360144/article/details/79966094HTTPS&…

北理工嵩天Python语言程序设计笔记(6 函数和代码复用)

前言 本文是对《北理工 嵩天/黄天宇/礼欣 Python语言程序设计》的学习笔记,供自己查阅使用。 文章目录 北理工嵩天Python语言程序设计笔记(目录)北理工嵩天Python语言程序设计笔记(2 Python基本语法元素)北理工嵩天…

3GPP R17空闲态省电特性

Paging Early Indication 为了进一步降低空闲态UE监听PDCCH的功耗,R17提出Paging Early Indication(PEI)方案。方案的主要思想是在PO(Paging Occasion)之前插入一个PEI-O(PEI Occasion),UE在解调到PEI信息之后,再确定是否需要解调PO信息。其中…

FPGA帧差算法实现图像识别跟踪,Verilog代码讲解全网最细,提供两套工程源码

之前我写过一篇关于FPGA帧差算法实现图像识别跟踪的文章,可以参考一下FPGA帧差算法实现图像识别跟踪 但那篇文章讲得不够细,这里讲得细一点: 运动目标检测原理:先将RGB图像转为灰度图只取亮度分量y,如果一个物体是运动…

【C++】如何修改set的值

问题&#xff1a;尝试通过begin方法得到的迭代器去修改值&#xff0c;发现会报错。 set<string> st{"hello", "world", "good"}; set<string>::iterator it st.begin(); *it "test"; 原因&#xff1a;我们可以在源码里…

三层交换机(三层配置基础命令)

作者介绍&#xff1a; ♥️作者&#xff1a;小刘在C站 ♥️每天分享课堂笔记&#xff0c;一起努力&#xff0c;共赴美好人生&#xff01; ♥️夕阳下&#xff0c;是最美的绽放。 目录 一.什么是三层交换机 二.为什么使用三层交换机 三.层交换机的原理 1.传统的mls 2.快速转…

文件的基本操作

文章目录创建文件删除文件打开文件关闭文件读文件写文件这些基本功能都是操作系统提供给应用程序的系统调用创建文件 提供的参数 所需的外存空间大小文件的存放路径文件名&#xff08;操作系统会有对应的默认名&#xff09; 操作系统做的工作 在外存中找文件所需的空间——空闲…

Python趣味算法入门 - 百钱百鸡

问题描述 中国古代数学家张邱建在他的《算经》中提出了一个著名的“百钱百鸡问题”&#xff1a;一只公鸡值五钱&#xff0c;一只母鸡值三钱&#xff0c;三只小鸡值一钱&#xff0c;现在要用百钱买百鸡&#xff0c;请问公鸡、母鸡、小鸡各多少只&#xff1f; 分析 这也是经典问…

所见即所得即MySQL函数

✨✨hello&#xff0c;愿意点进来的小伙伴们&#xff0c;你们好呐&#xff01; &#x1f43b;&#x1f43b;系列专栏&#xff1a;【MySQL初阶】 &#x1f432;&#x1f432;本篇内容&#xff1a;MySQL函数的详解 &#x1f42f;&#x1f42f;作者简介:一名现大二的三非编程小白&…

【Spring】核心部分之IOC:通过列举代码例子,从底层刨析,深入源码,轻轻松松理解Spring的核心IOC,IOC有这一篇足以

IOC一&#xff0c;概念和原理1.概念&#xff1a;控制反转2.原理&#xff1a;&#xff08;xml解析&#xff0c;工厂模式&#xff0c;反射&#xff09;3.IOC接口&#xff1a;两个主要容器实现类&#xff08;加载xml配置文件&#xff09;二&#xff0c;操作Bean管理1.基于 xml 配置…

React - 实现瀑布流加载

React - 实现瀑布流加载一. 瀑布流实现1.1 处理重复请求问题一. 瀑布流实现 先来看下原本的效果&#xff0c;一次性加载完所有的信息然后展示&#xff1a; 其次&#xff0c;我们需要去监听这个滚轮的滚动事件&#xff0c;那么React页面就可以添加一个监听器&#xff1a; use…

SpringSecurity Oauth2实战 - 04 自定义AuthProvider实现登录认证

文章目录1. 搭建资源服务器1. Token存储配置类 TokenStoreAutoConfiguration2. 资源服务器配置类 ResourceServerAutoConfiguration3. 在META-INF/spring.factories文件下添加配置类2. 搭建授权服务器1. 密码加密配置类 PasswordEncodeConfig2. RestTemplateConfig3. 授权服务器…

k3s 离线部署指南

文章目录1. 简介2. Docker 手动部署镜像方式2.1 安装docker2.2 导入镜像2.3 安装 k3s2.4 查看3. Containerd 手动部署镜像方式3.1 导入镜像到 containerd 镜像列表3.2 授予可执行权限3.3 安装 K3s4. Containerd 私有镜像仓库方式4.1 配置 K3s 镜像仓库4.2 授予可执行权限4.3…

集合(Set)和有序集合(ZSet)的基本使用方法详解【Redis】

文章目录一. Redis中的集合(Set)1.1基本的一些操作1.1.1 smembers查看集合中的所有成员1.1.2 scard删除成员数量1.1.3 smove移动成员1.1.4 sinterstore 存储俩个集合的交集二.Redis中的有序集合(ZSet)2.1 基本的一些操作2.1.1 zadd添加1到多个成员2.1.2 zcount 返回指定分数区间…

【HarmonyOS】鸿蒙轻量级智能穿戴应用可以集成华为分析SDK吗?

1、问题描述 我们的项目是基于鸿蒙系统开发的轻量级智能穿戴应用&#xff0c;目前在做的主要是运动手表GT3。 我们在项目中使用了华为分析服务&#xff0c;但是在Build Hap时出现问题&#xff1a; 因此&#xff0c;我们想了解轻量级智能穿戴应用项目中是否能够集成华为分析服…

计算机毕业设计(附源码)python在线影评系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…