【算法刷题】链表笔试题解析(1)

news/2024/5/9 0:02:00/文章来源:https://blog.csdn.net/acm_pn/article/details/137056792

 

一、链表分割

题目描述:

链接:链表分割

d908ed776515446ba1ee0ca64e55793b.png

题目分析:

        这题直接处理并不好做,我们可以构建前后两个链表,将小于x值的结点放在链表a内,将其它结点放在链表b内,这样将原链表遍历完后,原链表就自然地分成了两部分,最后将两个链表拼接起来就行了。

如果你以为这题到这里就完了,那这题就不会被分在“较难题”里了

        做算法题,我们一定要细心,要考虑好程序可能会面临的所有情况,仔细梳理一下,你会发现这道题主要会有四种情况:

1、给定链表为空

2、链表中的值有大于x的,也有小于x的

3、链表中所有结点的值都大于x

4、链表中所有节点的值都小于x

这时问题就很明显了,我们之前的思路只能处理第二种情况,遇到其它情况的时候就会出现问题。

比如在第三种情况下,由于没有小于x的结点,所以链表a的头尾指针都不能指向具体的结点,这时如果再通过a链表的尾节点指向b链表的方式链接,就会出现空指针异常导致程序出错了

因此我们还需要分别处理其它三种情况:

1、因为链表为空,所以不需要处理,直接返回头结点即可

3、此时a链表的头指针应该为空,只需要返回b链表的头结点即可

4、此时b链表为空,正常让a的尾结点指向b的头,直接返回头结点即可

注意:二三种情况时需要将b的尾结点的后驱结点置空,这样才能构建一个正常的单链表


代码实现:

public class Partition {public ListNode partition(ListNode pHead, int x) {// write code hereif(pHead==null){return pHead;}ListNode as=null;ListNode ae=null;ListNode bs=null;ListNode be=null;ListNode cur=pHead;while(cur != null){if(cur.val<x){if(as==null){as=cur;ae=cur;}else{ae.next=cur;ae=ae.next;}         }else{if(bs==null){bs=cur;be=cur;}else{be.next=cur;be=be.next;} }cur=cur.next;}if(as==null){be.next=null;return bs;}ae.next=bs;if(bs!=null){be.next=null;}return as;}
}

二、链表的回文结构

题目描述:

链接:链表的文结构

da5cea59b7bc46d2923b22b02920ddaf.png

题目分析:

有些人看到这题的第一想法可能是遍历一遍链表,将链表中的值都存在一个数组中,然后用数组的处理方法来判断是否回文,从而大大简化题目难度。

这的确是一个不错的思路,但你有没有发现题目还有以下要求:

时间复杂度为O(n),额外空间复杂度为O(1)的算法

如果你不知道什么是时间复杂度和空间复杂度的话,可以看看博主的这篇文章:博客链接

很明显,数组的空间复杂度是O(N),不符合题目要求,出题者明显不想让你用这么粗暴的方式解题

这里博主提供一个简单的思路:

我们可以先将链表反转,然后判断两个链表相应位置上的值是否相等即可

 

代码实现:

public class PalindromeList {public boolean chkPalindrome(ListNode A) {// write code hereif(A==null||A.next==null){return true;}ListNode cur1=A.next;ListNode cur2=A.next;ListNode head=A;head.next=null;while(cur1!=null){cur2=cur1.next;cur1.next=head;head=cur1;cur1=cur2;}while(A!=null){if(A.val!=head.val){return false;}A=A.next;head=head.next;}return true;}
}

三、链表的中间节点

题目描述:

链接: 链表的中间节点

52df901407e04f78afeb34a52a34d5b9.png

题目分析:

我们可以用快慢指针的方法,定义一个快指针fast每次走两步,再定义一个慢指针每次走一步,这样在快指针遍历完链表时,慢指针就正好位于中间位置了

注意:链表的长度可能是奇数也可能是偶数,当结点数为奇数时,fast是走不到最后一个的,如果强行每次都走两步的话最后会出现空指针异常,不过仔细观察你会发现,当fast走到倒数第二位时,slow就刚好位于中间结点了,因此我们只要改变一下循环退出条件即可

代码实现:

class Solution {public ListNode middleNode(ListNode head) {ListNode cur1=head;ListNode cur2=head;while(cur1 !=null&&cur1.next!=null){cur1=cur1.next.next;cur2=cur2.next;}return cur2;}
}

 

四、相交节点

题目描述:

链接:相交节点

d5e2d95c48bd4b1aa612c11944789f5c.png

 

题目分析:

        如果两个链表等长的情况下,这题就非常简单了,只需要同时让指针a、b分别从两个链表的头结点出发,判断是否有结点相等即可,但显然,两个链表的长度未必是相等的。

        这时我们可以先让指针a、b分别遍历两个链表,直到有一个链表被遍历完后,这时长链表指针与长链表尾结点的距离正好是两个链表长度的差值,这时再令一指针x指向长链表的头结点,再一次让之前没遍历完的指针y与新指针x进行遍历,直到老指针y指向长链表的尾结点,这时x与长链表的尾结点的距离正好等于短链表的长度,接着就可以用处理两个等长链表的方式来处理了


代码实现:

public class Solution {if(headA==null&&headB==null)return null;ListNode cur1=headA;ListNode cur2=headB;while(cur1!=null&&cur2!=null){cur1=cur1.next;cur2=cur2.next;}if(cur1==null){cur1=headB;}else{cur2=headA;}while(cur1!=null&&cur2!=null){cur1=cur1.next;cur2=cur2.next;}if(cur1==null){cur1=headB;}else{cur2=headA;}while(cur1!=null&&cur2!=null){if(cur1==cur2){return cur1;}cur1=cur1.next;cur2=cur2.next;}return null;}

 

 

五、返回倒数第k个节点

题目描述:

链接:返回倒数第k个节点

ba9d2323bd824f7f842222b741a418a8.png

题目分析:

我们可以定义两个指针,先让指针1遍历链表,同时记录指针走过的步数s,当s=k时,开始让指针2从头结点开始遍历链表,当指针1指向链表的尾结点时,指针2所指向的结点就是倒数第k个结点了

注意:可能出现k值大于链表长度或k值小于零的情况,

当k<0时,题目显然是无解的,直接return-1即可

当k大于链表长度时,我们可以通过记录指针1走过的步数s的大小来判断,如果指针1遍历完链表时,s任小于k,就说明k值超过了链表的长度,直接return -1即可


代码实现:

public class Solution {public int kthToLast(ListNode head, int k) {if (k < 0) {return -1;}ListNode cur1=head;ListNode cur2=head;int s=0;while(cur1!=null){cur1=cur1.next;if(s==k){cur2=cur2.next;}else{s++;}}if(s<k){return -1;}else{return cur2.val;}}
}

 

总结

那么本篇文章就到此为止了,如果觉得这篇文章对你有帮助的话,可以点一下关注和点赞来支持作者哦。作者还是一个萌新,如果有什么讲的不对的地方欢迎在评论区指出,希望能够和你们一起进步✊

6d1311864a3f47b8a5ba9bb8a3f457cc.png

 

 

 

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

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

相关文章

基于springboot+vue+Mysql的闲一品交易平台

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

缓存菜品、套餐、购物车相关功能

一、缓存菜品 通过缓存的方式提高查询性能 1.1问题说明 大量的用户访问导致数据库访问压力增大&#xff0c;造成系统响应慢&#xff0c;用户体验差 1.2 实现思路 优先查询缓存&#xff0c;如果缓存没有再去查询数据库&#xff0c;然后载入缓存 将菜品集合序列化后缓存入red…

如何利用nginx在windows系统上搭建一个文件服务器

1&#xff1a;先下载windows版的nginx 官网 http://nginx.org/ 下载完后注意端口号&#xff08;默认端口号为&#xff1a;80&#xff09;是否被占用 启动nginx服务 地址为localhost的 如果出现 Welcome to nginx 就说明启动成功 2&#xff1a;然后进入conf文件里修改配置 …

题目:摆花(蓝桥OJ 0389)

问题描述&#xff1a; 题解&#xff1a; #include <bits/stdc.h> using namespace std; using ll long long; const int N 105; const ll p 1e6 7; ll a[N], dp[N][N];int main() {int n, m; cin >> n >> m;for(int i 1; i < n; i)cin >> a[i…

EdgeGallery开发指南

API接口 简介 EdgeGallery支持第三方业务系统通过北向接口网关调用EdgeGallery的业务接口。调用流程如下图所示&#xff08;融合前端edgegallery-fe包含融合前端界面以及北向接口网关功能&#xff0c;通过浏览器访问时打开的是融合前端的界面&#xff0c;通过IP:Port/urlPref…

网络原理(6)——IP协议

目录 一、网段划分 现在的网络划分&#xff1a; 1、一般情况下的家庭网络环境 2、IP地址 3、子网掩码 4、网关 以前的网络划分&#xff1a; 二、特殊IP 1、环回 IP 2、主机号为全 0 的IP 3、广播地址IP 三、路由选择&#xff08;路线规划&#xff09; 一、网段划分…

vue3+ts+element home页面侧边栏+头部组件+路由组件组合页面教程

文章目录 效果展示template代码script代码样式代码 效果展示 template代码 <template><el-container class"home"><el-aside class"flex" :style"{ width: asideDisplay ? 70px : 290px }"><div class"aside-left&q…

KubeSphere简单介绍及安装使用

KubeSphere 概述 官网地址&#xff1a;https://kubesphere.io/zh/ 什么是 kubesphere KubeSphere 是一个开源的多云容器管理平台&#xff0c;旨在简化企业级 k8s 集群的部署、管理和运维。它提供了一个可视化的管理界面&#xff0c;帮助用户更轻松地管理和监控 k8s 集群&…

vscode使用Runner插件将.exe文件统一放到一个目录下

找到右下角管理&#xff0c;点击扩展。 找到Code Runner插件&#xff0c;打开扩展设置。 向下翻&#xff0c;找到Executor Map&#xff0c;点击在settings.json中编辑。 在c和c的配置命令栏中增加\\\output\\即可。&#xff08;增加的目录不能自动创建&#xff0c;需要手动创建…

基于大语言模型的云故障根因分析|顶会EuroSys24论文

*马明华 微软主管研究员 2021年CCF国际AIOps挑战赛程序委员会主席&#xff08;第四届&#xff09; 2021年博士毕业于清华大学&#xff0c;2020年在佐治亚理工学院做访问学者。主要研究方向是智能运维&#xff08;AIOps&#xff09;、软件可靠性。近年来在ICSE、FSE、ATC、EuroS…

t-rex2开放集目标检测

论文链接&#xff1a;http://arxiv.org/abs/2403.14610v1 项目链接&#xff1a;https://github.com/IDEA-Research/T-Rex 这篇文章的工作是基于t-rex1的工作继续做的&#xff0c;核心亮点&#xff1a; 是支持图片/文本两种模态的prompt进行输入&#xff0c;甚至进一步利用两…

简单的SpringMVC项目创建流程(基于XML文件(了解))

1&#xff1a;首先创建一个maven项目&#xff0c;并在pom.xml文件中导入依赖 <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 …

浅模仿小米商城布局(有微调)

CSS文件 *{margin: 0;padding: 0;box-sizing: border-box; }div[class^"h"]{height: 40px; } div[class^"s"]{height: 100px; } .h1{width: 1528px;background-color: green; } .h11{background-color:rgb(8, 220, 8); } .h111{width: 683px;background-c…

Linux 基础命令1

目录 一.Linux优点&#xff08;优势&#xff09; 二.Shell 三.Linux命令 四.help命令 五.Linux目录结构 六.目录操作 七.路径 一.Linux优点&#xff08;优势&#xff09; 1.一切都是一个文件 2.系统中拥有小型 &#xff0c;轻量级&#xff0c;单一用途的程序 3.避免令…

【循环神经网络rnn】一篇文章讲透

目录 引言 二、RNN的基本原理 代码事例 三、RNN的优化方法 1 长短期记忆网络&#xff08;LSTM&#xff09; 2 门控循环单元&#xff08;GRU&#xff09; 四、更多优化方法 1 选择合适的RNN结构 2 使用并行化技术 3 优化超参数 4 使用梯度裁剪 5 使用混合精度训练 …

MySQL高阶SQL语句

文章目录 MySQL高阶SQL语句MySQL常用查询1、按关键字排序1.1 语法1.2 ASC和DESC1.3 对数据表中信息进行排序1.3.1 普通排序1.3.2 结合where进行条件过滤1.3.3 对多个字段进行排序 2、区间判断及查询不重复记录2.1 and/or —— 且/或2.1.1 普通查询2.1.2 嵌套/多条件查询 2.2 di…

验证码demo(简单实现)

前言 我们注意到我们登录网站的时候经常会用到网络验证码,今天我们就简单实现一个验证码的前后端交互问题,做一个小demo 准备 我们这里并不需要依靠原生的java来实现,而是只需要引入一个maven依赖,使用现成的封装好的即可,这是我使用的是hutool工具包 网址:Hutool&#x1f36c;…

Linux 收发网络包的流程

应用层&#xff1a; 功能&#xff1a;提供应用程序间通信。例子&#xff1a;电子邮件客户端如Outlook或Thunderbird&#xff0c;它们提供用户界面来发送和接收电子邮件。这些客户端使用SMTP&#xff08;用于发送邮件&#xff09;和IMAP或POP3&#xff08;用于接收邮件&#xff…

计算机软件安全

一、软件安全涉及的范围 1.1软件本身的安全保密 软件的本质与特征&#xff1a; 可移植性 寄生性 再生性 可激发性 攻击性 破坏性 …… 知识产权与软件盗版 软件商品交易形式不透明&#xff0c;方式多样&#xff0c;传统商标标识方法不适用&#xff1b; 盗版方法简捷…

蓝桥杯刷题之路径之谜

题目来源 路径之谜 不愧是国赛的题目 题意 题目中会给你两个数组&#xff0c;我这里是分别用row和col来表示 每走一步&#xff0c;往左边和上边射一箭&#xff0c;走到终点的时候row数组和col数组中的值必须全部等于0这个注意哈&#xff0c;看题目看了半天&#xff0c;因为…