当前位置: 首页 > news >正文

网站开发百度百科网站用哪些系统做的好

网站开发百度百科,网站用哪些系统做的好,企业网站建设定制开发服务,营销网站模板html欢迎大家来我们主页进行指导 LaNzikinh-CSDN博客 160. 相交链表 - 力扣(LeetCode) 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。 图示两个链表在节…

欢迎大家来我们主页进行指导
LaNzikinh-CSDN博客


160. 相交链表 - 力扣(LeetCode)

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

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

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

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

自定义评测:

评测系统 的输入如下(你设计的程序 不适用 此输入):

  • intersectVal - 相交的起始节点的值。如果不存在相交节点,这一值为 0
  • listA - 第一个链表
  • listB - 第二个链表
  • skipA - 在 listA 中(从头节点开始)跳到交叉节点的节点数
  • skipB - 在 listB 中(从头节点开始)跳到交叉节点的节点数

评测系统将根据这些输入创建链式数据结构,并将两个头节点 headA 和 headB 传递给你的程序。如果程序能够正确返回相交节点,那么你的解决方案将被 视作正确答案 。

首先做这个题目有两个核心的关键就是,1.你要判断它是不是相交的。2.它的交点


思路一:暴力求解

依次去A链表中的每个节点跟B链表中的所有节点比较,如果有地址相同的节点,就是相交,第一个相同的就是交点

时间复杂度为O(N^2),非常麻烦,这里就不多说了,我们直接来说思路二


思路二:长度差法

核心:尾结点相同,就是相交否则就不相交,长的链表先走长度差步,再同时走,第一个相同的就是交点

2.1计算长度

先保存两个头结点用来比较长度,因为我遍历完了两个链表,所以把是不是相交一起判断了

//先保存两个头结点用来比较长度
struct ListNode* tailA = headA;
struct ListNode* tailB = headB;
//计算A的长度
int lenA = 1;
while (tailA->next != NULL)
{lenA++;tailA = tailA->next;
}
//计算B的长度
int lenB = 1;
while (tailB->next != NULL)
{lenB++;tailB = tailB->next;
}
//是不是相交一起判断
if (tailA != tailB)
{return NULL;
}

2.2判断那个长?

这个用了一个非常巧妙的办法来写出了如何判断这两个长,因为我不知道这两个最开始到底是谁长

//abs取绝对值
int gap = abs(lenA - lenB);
//先假设A长
struct ListNode* long = headA;
struct ListNode* short = headB;
//在做出判断,如果A短就互换
if (lenA < lenB)
{struct ListNode* long = headB;struct ListNode* short = headA;
}

2.3长的先走,短的在一起走

//长的先走gap步
while (gap--)
{long = long->next;
}
//等长的走完,在一起走,之后返回向遇点就可以了
while (long != short)
{long = long->next;short = short->next;
}
//返回short也可以
return long;

2.4总代码

struct ListNode* getIntersectionNode(struct ListNode* headA, struct ListNode* headB)
{//先保存两个头结点用来比较长度struct ListNode* tailA = headA;struct ListNode* tailB = headB;//计算A的长度int lenA = 1;while (tailA->next != NULL){lenA++;tailA = tailA->next;}//计算B的长度int lenB = 1;while (tailB->next != NULL){lenB++;tailB = tailB->next;}if (tailA != tailB){return NULL;}//abs取绝对值int gap = abs(lenA - lenB);//先假设A长struct ListNode* long = headA;struct ListNode* short = headB;//在做出判断,如果A短就互换if (lenA < lenB){struct ListNode* long = headB;struct ListNode* short = headA;}//长的先走gap步while (gap--){long = long->next;}//等长的走完,在一起走,之后返回向遇点就可以了while (long != short){long = long->next;short = short->next;}//返回short也可以return long;
}

 

http://www.laogonggong.com/news/56930.html

相关文章:

  • 做我的世界背景图的网站电商平台搭建的注意事项
  • 创建网站目录应注意宁波seo网页怎么优化
  • 门户网站的发展趋势设计类投稿网站
  • 网站设计的公司皆选奇点网络广东省住房和城乡建设厅官方网站
  • 公司网站销售怎么做的中国知名的品牌策划公司
  • 专业做网站优化需要多久合作平台网
  • app定制网站开发网站建设挂什么费用
  • 嘉兴做网站的哪家好高端建造
  • 果洛电子商务网站建设哪家快旅游目的地网站建设的流程
  • 网站开发选定制还是模板网站建设客户沟通模块
  • 多语言网站一个域名做移动网站优化快速
  • 一篇网站设计小结如何做seo整站优化
  • 福州火车站最新消息注册企业查询
  • 个人网站建立步骤建设网站资质查询
  • 手机数码网站企业门户网站建设方案
  • 网站建设2018wordpress分类目录样式
  • thinkphp旅游网站源码在家怎么提升学历
  • 建设银行学习网站中企动力科技股份有限公司网站官网
  • 一个网站做多少关键词网站制作过程内容
  • 广告设计网站免费个人网站开发的现状
  • ipv6网站如何做网站建设视频下载
  • 网站源码交易网WordPress个人知识库
  • 南油网站建设哪有做网站推广
  • 网站建设模板软件手机app推荐
  • 网站关键词几个最好天津网站设计
  • wordpress完全单页上海网站代优化
  • chatgpt 网址长沙网站seo厂家
  • php是用来做网站的吗wordpress 4.7优化
  • 建设外贸类网站wordpress文章定时发布
  • 如何在本地搭建网站ps网站怎么做滑动背景图片