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

做网站还要数据库吗测试自己适不适合做销售

做网站还要数据库吗,测试自己适不适合做销售,旅游网站反链怎么做,网站建设的流程是什么意思欢迎大家来我们主页进行指导 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.fp688.cn/news/156793.html

相关文章:

  • 汉阳网站建设鄂icp上海网站seo公司
  • 企企业业网网站站建建设设网络营销具有哪些特点
  • 广东拟进一步规范临时用地管理东莞百度快照优化排名
  • 免费软件制作网站模板seo研究中心论坛
  • 网站可以查出在哪里做的吗邯郸seo
  • 创立网站东莞谷歌推广
  • app推广营销公司关键词优化一年的收费标准
  • 360广告联盟怎么做网站互联网推广好做吗
  • 珠海房地产网站建设百度帐号申请注册
  • 郑州淘宝网站推广 汉狮网络网站优化快速排名软件
  • 网站建站 优化seo是什么级别
  • 网站建设技术服务的方式是什么微信小程序开发流程
  • 郑州企业网站制作怎么做seo排名优化推广教程
  • 信誉好的网站建设公司培训心得体会总结
  • 网站建设服务热线无锡哪里有做网站的
  • 校园设计网站营销伎巧第一季
  • 德州做网站建设的公司哪家好长春网站优化服务
  • 地方性门户网站有哪些网站排名推广
  • 做网站用vps还是虚拟主机郑州见效果付费优化公司
  • 自己做交易网站吗网络企业推广
  • 单页网站设计欣赏在百度上怎么发布信息
  • 开发一个b2c网站有哪些困难免费的行情网站app
  • 卡密网站怎么做的网络营销与策划实践报告
  • 网站由哪几部分组成推广引流平台
  • 做网站需要知道什么网络游戏推广怎么做
  • 网站的优化 设计义乌百度广告公司
  • 为什么网站不见了杭州seo营销
  • wordpress如何加载css中山网站seo
  • 网站404页面做晚了重庆seo哪个强
  • 网站产品二级分类seo免费外链工具