数据结构(01)——链表OJ

目录

移除链表元素

思路1

不创建虚拟头节点

思路2

创建虚拟头节点

反转链表

寻找链表中间节点

判断链表是否相交

回文链表

环形链表

环形链表||


移除链表元素

. - 力扣(LeetCode)

要想移除链表的元素,那么只需要将目标节点的前一个节点的next指针指向目标节点下一个节点的next指针

但是这里就会出现一个问题,如果头节点是目标值怎么办?

此时就有两种思路,一种就是分开讨论,当头节点为目标值时,头节点的next指针指向下一个节点,使下一个节点成为新的头节点

另一种就是创建虚拟头节点,这样在删除的时候就可以统一代码风格

思路1

不创建虚拟头节点

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
struct ListNode* removeElements(struct ListNode* head, int val) 
{//头节点为目标值的情况while(head!=NULL&&head->val==val){head = head->next;}//处理完头节点为目标值的情况ListNode* pcur = head;while(pcur!=NULL&&pcur->next!=NULL){if(pcur->next->val==val){pcur->next = pcur->next->next;}else{pcur = pcur->next;}}return head;
}

思路2

创建虚拟头节点

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
struct ListNode* removeElements(struct ListNode* head, int val) 
{//使用虚拟头节点dummyhead来进行删除操作ListNode* dummyhead = (ListNode*)malloc(sizeof(ListNode));dummyhead->next = head;ListNode* pcur = dummyhead;while(pcur&&pcur->next){if(pcur->next->val==val){pcur->next = pcur->next->next;}else{pcur = pcur->next;}}return dummyhead->next;
}

反转链表

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

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
struct ListNode* reverseList(struct ListNode* head) 
{ListNode* cur = head;ListNode* prev = NULL;ListNode* tmp = NULL;while(cur){tmp = cur->next;cur->next = prev;prev = cur;cur = tmp;}return prev;
}

让我们画一个图来解释这个代码

 

当我们遍历完这个链表之后,返回的prev就会依次从后往前返回链表中的元素了 

寻找链表中间节点

这道题的思路是双指针法,一个快指针,一个慢指针,快指针每次走两步,慢指针每次走一步,当快指针走到链表结尾时,慢指针的位置就是链表的中间节点

876. 链表的中间结点 - 力扣(LeetCode)

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
struct ListNode* middleNode(struct ListNode* head) 
{ListNode* slow = head;ListNode* fast = head;while(fast&&fast->next){slow = slow->next;fast = fast->next->next;}return slow;
}

判断链表是否相交

如果要判断链表是否相交,那么就要分别遍历这两个链表,判断他们的尾节点的地址是否相同,其次再找到相交的位置的元素

. - 力扣(LeetCode)

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) 
{int lenA = 1;int lenB = 1;ListNode* curA = headA;ListNode* curB = headB;while(curA->next){curA = curA->next;lenA++;}while(curB->next){curB = curB->next;lenB++;}//判断地址是否相等if(curA!=curB){return NULL;}//使用假设法int gap = abs(lenA-lenB);ListNode* longlist = headA;ListNode* shortlist = headB;if(lenB>lenA){longlist = headB;shortlist = headA;}//先让长指针走到短指针的位置,然后开始地址比较while(gap--){longlist = longlist->next;}while(shortlist!=longlist){longlist = longlist->next;shortlist = shortlist->next;}return shortlist;
}

回文链表

回文链表的思路是先找到链表的中间节点,然后将中间节点后面的元素反转,再和前面的元素一个一个比较,如果都i相等,那么就是回文链表

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
typedef struct ListNode ListNode;bool isPalindrome(struct ListNode* head)
{//先找到链表的中间元素ListNode* slow = head;ListNode* fast = head;while(fast&&fast->next){slow = slow->next;fast = fast->next->next;}//反转中间节点之后的元素ListNode* cur = slow;ListNode* prev = NULL;ListNode* tmp = NULL;while(cur){tmp = cur->next;cur->next = prev;prev = cur;cur = tmp;}while(head&&prev){if(head->val!=prev->val){return false;}prev = prev->next;head = head->next;}return true;
}

环形链表

. - 力扣(LeetCode)

判断是否为环形链表,依然是快慢指针的方法,非常简单,直接上代码了

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
bool hasCycle(struct ListNode *head) 
{ListNode* slow = head;ListNode* fast = head;while(fast&&fast->next){slow = slow->next;fast = fast->next->next;if(slow==fast){return true;}}return false;
}

环形链表||

环形链表||

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
struct ListNode *detectCycle(struct ListNode *head) 
{ListNode* slow = head;ListNode* fast = head;while(fast&&fast->next){slow = slow->next;fast = fast->next->next;//判断是否有环if(slow==fast){ListNode* meet = head;while(meet!=slow){slow = slow->next;meet = meet->next;}return meet;}}return NULL;
}

环形链表||

在这个代码中,我们将meet从head开始遍历,那么当meet和slow相遇的节点就是环形链表的入口处

那么我们如何证明呢?

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

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

相关文章

XMind轮播图banner测试点

banner测试点 显示1到5张banner图片 [1,5] 6 1 一张不轮播 5 3 0可选 自动轮播,3秒切换一张 鼠标悬停,不轮播 实心为当前图 点击可以跳转 点击左,切换一张图片 点击右, 切换一张图片…

Arch Linux安装macOS

安装需要的包 sudo pacman -S qemu-full libvirt virt-manager p7zip yay -S dmg2img安装步骤 cd ~ git clone --depth 1 --recursive https://github.com/kholia/OSX-KVM.git cd OSX-KVM # 选择iOS版本 ./fetch-macOS.py #将上一步下载的BaseSystem.dmg转换格式 dmg2img -…

【Git】如何在.gitignore忽略已经被上传到git上的文件,并且同步到线上

【Git】如何在.gitignore忽略已经被上传到git上的文件,并且同步到线上 如果你想要 .gitignore 忽略已经上传到 Git 仓库的文件,但是希望在远程仓库上也排除这些文件,你需要执行以下步骤: 更新 .gitignore 文件: 首先,…

【中级软件设计师】上午题12-软件工程(3):项目活动图、软件风险、软件评审、软件项目估算

【中级软件设计师】上午题12-软件工程(3) 1 软件项目估算1.1 COCOMO估算模型1.2 COCOMOⅡ模型 2 进度管理2.1 gantt甘特图2.2 pert图2.3 项目活动图2.3.1 画项目图 3 软件配置管理4 软件风险4.1 风险管理4.2 风险识别4.3 风险预测4.4 风险评估4.5 风险控…

Baidu comate智能编程助手评测

Baidu comate智能编程助手评测 作者:知孤云出岫 目录 一. 关于comate产品 二. 关于comate产品体验 三. 关于实际案例. 四. 关于baidu comate编程助手的实测体验感悟 五. …

Java包装类,128陷阱

包装类 基本数据类型都有自己对应的包装类,因为Java本质是面向对象编程的,一切的内容在Java看来都是对象 但是基本数据类型没有类,也没有对象,这样就有了矛盾 所以诞生了基本类型的包装类 基本数据类型: byte,short,…

014、Python+fastapi,第一个后台管理项目走向第14步:建立python+fastapi项目,创建common通用模块

一、说明 通用模块主要是完成文件的上传下载,抄吧,要不然怎么叫通用模块呢? 我把RuoYi-Vue3-FastAPI中的验证码模块放在这里了,我觉得验证也比较通用吧, 二、添加common通用模块 1、通用模块没有数据表&#xff0c…

冯喜运:4.30现货黄金涨跌互现,最新黄金原油趋势分析

【黄金消息面分析】:上周五公布的数据,美国3月核心PCE年率维持前值不变,美国4月一年期通胀率预期上升,显示通胀顽固并有所回升,但其经济数据美国3月个人支出月率和美国4月密歇根大学消费者信心指数终值则低于预期和前值…

WEB攻防-PHP特性-metinfoCMS审计实例

前置知识&#xff1a;PHP函数缺陷 测试环境&#xff1a;MetInfo CMS 函数缺陷导致的任意文件读取 漏洞URL&#xff1a;/include/thumb.php?dir 漏洞文件位置&#xff1a;MetInfo6.0.0\app\system\include\module\old_thumb.class.php <?phpdefined(IN_MET) or exit(No…

深度学习 --- stanford cs231学习笔记(一)

stanford cs231学习笔记(一) 1&#xff0c;先是讲到了机器学习中的kNN算法&#xff0c;然后因为kNN分类器的一些弊端&#xff0c;引入了线性分类器。 kNN算法的三大弊端&#xff1a; (1)&#xff0c;计算量大&#xff0c;当特征比较多时表示性差 (2)&#xff0c;训练时耗时少…

慢SQL问题全解析:原因诊断与性能优化策略

慢SQL的定义&#xff1a; 执行时间长的 慢SQL的筛选&#xff1a; 1.使用MySQL自带的日志 查看慢查询日志是否开启&#xff1a; SHOW VARIABLES LIKE %slow_query_log%; 开启慢查询日志&#xff1a;使用该方法开启MySQL的慢查询日志只对当前数据库生效&#xff0c;如果MySQ…

HF区块链链码基础

链码生命周期 一 . 链码准备 准备文件 . 在测试目录下创建chaincode,拷贝测试链码进 chaincode目录,拷贝 set-env.sh 脚本进 scripts 目录 二. 打包链码 打包测试链码 export FABRIC_CFG_PATH${PWD}/config peer lifecycle chaincode package ./chaincode/chaincode_basic.…

Centos7使用Nginx配置HTTPS正向代理

Centos7使用Nginx配置HTTPS正向代理 Nginx默认安装只支持代理HTTP, 不支持代理 HTTPS, 如果需要支持HTTPS需要在Nginx编译时加入 ngx_http_proxy_connect_module. 文件准备 从 ngx_http_proxy_connect_module 模块仓库下载源代码压缩包, 并确定支持的 Nginx 版本 仓库地址: …

每周一算法:单源次短路

题目描述 “您的个人假期”旅行社组织了一次比荷卢经济联盟的巴士之旅。 比荷卢经济联盟有很多公交线路。每天公共汽车都会从一座城市开往另一座城市。沿途汽车可能会在一些城市&#xff08;零或更多&#xff09;停靠。 旅行社计划旅途从 S S S 城市出发&#xff0c;到 F …

C语言进阶|链表经典OJ题

✈移除链表元素 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff0c;并返回 新的头节点 。 方法一&#xff1a; 遍历链表找到所有等于val的节点&#xff0c;再执行删除操作删除这些节点。 方法二&#xff1a; …

算法必备数学基础:图论方法由浅入深实践与应用

作者介绍&#xff1a;10年大厂数据\经营分析经验&#xff0c;现任大厂数据部门负责人。 会一些的技术&#xff1a;数据分析、算法、SQL、大数据相关、python 欢迎加入社区&#xff1a;码上找工作 作者专栏每日更新&#xff1a; LeetCode解锁1000题: 打怪升级之旅 python数据分析…

深度探索DreamFusion:AI和3D建模的革命

在人工智能技术迅猛发展的今天&#xff0c;DreamFusion代表了一个新的突破&#xff0c;它是一种将文本描述转化为3D模型的技术。本文旨在详细解读DreamFusion的工作原理、应用场景以及它如何改变3D建模和视觉艺术领域。 一、DreamFusion简介 DreamFusion是一种结合了深度学习…

自动化密码填充:使用Python提高日常工作效率

密码是我们日常生活中难以逃脱的一部分。从解锁电脑到登录各种服务&#xff0c;我们需要记住无数的密码。幸运的是&#xff0c;通过Python和一些有用的库&#xff0c;我们可以简化填入密码的过程&#xff0c;使日常任务自动化变得简单。在本文中&#xff0c;我们将探讨如何使用…

SparkSQL---简介及RDD V.S DataFrame V.S Dataset编程模型详解

一、SparkSQL简介 SparkSQL&#xff0c;就是Spark生态体系中的构建在SparkCore基础之上的一个基于SQL的计算模块。SparkSQL的前身不叫SparkSQL&#xff0c;而叫Shark&#xff0c;最开始的时候底层代码优化&#xff0c;sql的解析、执行引擎等等完全基于Hive&#xff0c;总之Sha…

JimuReport报表源码反编译运行遇到的问题汇总

由来:突然有一天,发现使用jimu报表工具接入功能的时候很简单,能做出来简单、复杂、主子报表等一系列,然后发问有没有一种可能拿到源码?带着这种可能我们进入下面的操作。 1、环境准备 jimureport-spring-boot-starter:1.7.0 jar包 官方版本:GitHub - jeecgboot/JimuRe…