C语言每日一题(31)相交链表

力扣160.相交链表

题目描述

给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。

图示两个链表在节点 c1 开始相交

题目数据 保证 整个链式结构中不存在环。

注意,函数返回结果后,链表必须 保持其原始结构 。

思路分析

首先明确题目所要求的:

1.两链表是否相交?

2.如果相交的话,交点在哪?

首先解决第一个问题,判断是否相交。首先两个链表的头结点可能一样也可能不一样,但如果相交的话,它们的尾结点一定是同一个,那么我们可以分别遍历这两个链表到尾,如果一样的话就代表它们一定相交,否则直接返回false。

到第二个问题,找交点,如果俩链表同时从头遍历,再找它们相同的结点的话,那么当俩链表长度不同,指针就会错位,这是不靠谱的做法,正确的做法是,将它们遍历的起点进行统一后再进行遍历,直到碰到相同的结点,就是它们的交点。

如何统一起点呢?

首先找出较长链表,将俩链表长度的差当作步数,让长链表的指针先走完这些步数,这样两个链表的指针就统一了,之后两个指针再一起遍历,直到碰到相同结点停止,返回任意一个指针即是对应的交点。

完整代码

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {struct ListNode* curA=headA,*curB=headB;int lenA=1,lenB=1;//从1开始。while(curA){lenA++;curA=curA->next;}while(curB){lenB++;curB=curB->next;}if(curA!=curB)/判断是否相交{return NULL;}int n=abs(lenA-lenB);struct ListNode* longlist=headA,*shortlist=headB;//可以先假设其中一个为长链表。if(lenB>lenA)//如果不是在交换即可。{longlist=headB;shortlist=headA;}while(n--)//长指针先走{longlist=longlist->next;}while(shortlist!=longlist)//两个一起走,直到相同停下{shortlist=shortlist->next;longlist=longlist->next;}return longlist;//返回其中任意一个即可。
}

实现细节

注意比较的是该节点而非该节点的值,因为链表是乱序且无规律的。 

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

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

相关文章

【unity2021.3.6f】运行官方 Vuforia Hololens 2 Sample 教程

文章目录 前言一、创建unity项目二、导入unity1.添加到我的资源2.在package Manage 里面去找到,点击下载,下载完成后点击Import 如下图:3.导入途中会有窗口弹出 很多提示,都点击默认选项:Import 、Install/Upgrade 等 …

认识“协议”

文章目录: 什么是协议结构化的数据传输序列化和反序列化网络版本计算器 什么是协议 在计算机网络中,协议是指在网络中进行通信和数据交换时,双方遵循的规则和约定集合。它定义了数据的传输格式、顺序、错误处理、认证和安全性等方面的规范。 …

2018年五一杯数学建模C题江苏省本科教育质量综合评价解题全过程文档及程序

2019年五一杯数学建模 C题 江苏省本科教育质量综合评价 原题再现 随着中国的改革开放,国家的综合实力不断增强,中国高等教育发展整体已进入世界中上水平。作为一个教育大省,江苏省的本科教育发展在全国名列前茅,而江苏省13个地级…

openldap-sasl身份认证镜像

背景 在这篇文章中,AD域信息同步至openLDAP我们使用了SASL将身份验证从OpenLDAP委托给AD”这种方案,本文主要来构建此方案的docker镜像。 sasl官网:Cyrus SASL bitnami/openldap镜像地址:containers/Dockerfile bitnami/openl…

修改服务器端Apache默认根目录

目标:修改默认Apache网站根目录 /var/www/html 一、找到 DocumentRoot “/var/www/html” 这一段 apache的根目录,把/var/www/html 这个目录改 #DocumentRoot "/var/www/html" DocumentRoot "/home/cloud/tuya_mini_h5/build" 二、…

图论| 827. 最大人工岛 127. 单词接龙

827. 最大人工岛 题目:给你一个大小为 n x n 二进制矩阵 grid 。最多 只能将一格 0 变成 1 。返回执行此操作后,grid 中最大的岛屿面积是多少? 岛屿 由一组上、下、左、右四个方向相连的 1 形成。 题目链接:[827. 最大人工岛](ht…

obsidian和bookmaster

1 手动安装插件 插件地址:https://forum-zh.obsidian.md/t/topic/12333 安装file服务器 地址:http://www.rejetto.com/hfs/ hfs.exe可以改个端口 改成8866,ip地址也可以改成 127.0.0.1 # 因为安装到本地 如果要创建账户的话,就…

wpf devexpress在未束缚模式中生成Tree

TreeListControl 可以在未束缚模式中没有数据源时操作,这个教程示范如何在没有数据源时创建tree 在XAML生成tree 创建ProjectObject类实现数据对象显示在TreeListControl: public class ProjectObject {public string Name { get; set; }public string Executor {…

Kubernetes基础知识了解

一、Kubernetes简介 Kubernetes是一个轻便的和可扩展的开源平台,用于管理容器化应用和服务。通过Kubernetes能够进行应用的自动化部署和扩缩容。在Kubernetes中,会将组成应用的容器组合成一个逻辑单元以更易管理和发现。Kubernetes积累了作为Google生产…

微服务架构之路7,Nacos配置中心的Pull原理,附源码

目录 一、本地配置二、配置中心1、以Nacos为例:2、Pull模式3、也可以通过Nacos实现注册中心 三、配置中心提供了哪些功能四、如何操作配置中心1、配置注册2、配置反注册3、配置查看4、配置变更订阅 五、主流的微服务注册中心有哪些,如何选择?…

Echarts 实现两两柱图重叠(背景和实际值柱图)

Echarts实现两两重叠柱状图_echarts 重叠柱状图_Web_阿凯的博客-CSDN博客 引用启发的博客 先来效果: option {backgroundColor: #03213D,animation: true, // 控制动画是否开启animationDuration: 1000, // 动画的时长, 它是以毫秒为单位animationDuration: func…

(免费领源码)基于Vue+Node.js的宠物领养网站的设计与开发83352-计算机毕业设计项目选题推荐

摘 要 随着互联网大趋势的到来,社会的方方面面,各行各业都在考虑利用互联网作为媒介将自己的信息更及时有效地推广出去,而其中最好的方式就是建立网络管理系统,并对其进行信息管理。由于现在网络的发达,宠物领养网站的…