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

织梦 导航网站 模板设计素材网站永久

织梦 导航网站 模板,设计素材网站永久,红色基调网站,网站建设网页设计案例文章目录 两个链表的第一个公共结点问题描述示例说明示例 1示例 2 方法及实现方法描述代码实现 复杂度分析示例运行过程示例 1示例 2 总结备注 两个链表的第一个公共结点 问题描述 给定两个无环的单向链表#xff0c;找到它们的第一个公共节点。如果没有公共节点#xff0c… 文章目录 两个链表的第一个公共结点问题描述示例说明示例 1示例 2 方法及实现方法描述代码实现 复杂度分析示例运行过程示例 1示例 2 总结备注 两个链表的第一个公共结点 问题描述 给定两个无环的单向链表找到它们的第一个公共节点。如果没有公共节点则返回空。 要求 空间复杂度 O ( 1 ) O(1) O(1)时间复杂度 O ( n ) O(n) O(n)数据范围 链表长度 n ≤ 1000 n \leq 1000 n≤1000 输入数据分为三个部分 第一个链表的非公共部分。第二个链表的非公共部分。两个链表的公共部分。 后台会根据输入组装成两个单链表传入FindFirstCommonNode函数返回第一个公共节点。 示例说明 示例 1 输入 {1,2,3}, {4,5}, {6,7} 链表结构 第一个链表1 - 2 - 3 - 6 - 7 第二个链表4 - 5 - 6 - 7 输出 {6,7} 说明 两个链表从节点值为 6 的位置开始公共返回节点值为 6 的节点。 示例 2 输入 {1}, {2,3}, {} 链表结构 第一个链表1 第二个链表2 - 3 输出 {} 说明 两个链表没有公共节点返回 null。 方法及实现 方法描述 采用双指针法 设置两个指针 first 和 second 分别指向两个链表的头节点。当 first 和 second 不相等时指针逐步向后移动 如果某个指针到达链表尾部则跳转到另一个链表的头部。如果两个指针在某节点相遇则该节点为第一个公共节点。如果两指针遍历结束仍未相遇则无公共节点返回 NULL。 代码实现 struct ListNode* FindFirstCommonNode(struct ListNode* pHead1, struct ListNode* pHead2) {if (pHead1 NULL || pHead2 NULL) {return NULL; // 如果任何一个链表为空直接返回 NULL}struct ListNode* first pHead1; // 指针 first 初始指向链表1头部struct ListNode* second pHead2; // 指针 second 初始指向链表2头部// 当两个指针不相等时继续循环while (first ! second) {first (first ! NULL) ? first-next : pHead2; // 如果 first 到达末尾跳转到链表2头部second (second ! NULL) ? second-next : pHead1; // 如果 second 到达末尾跳转到链表1头部}return first; // 返回第一个公共节点或 NULL }复杂度分析 时间复杂度 每个指针最多遍历两个链表的长度总时间复杂度为 O ( n m ) O(n m) O(nm)其中 n n n 和 m m m 分别是两个链表的长度。 空间复杂度 只使用了两个指针空间复杂度为 O ( 1 ) O(1) O(1)。 示例运行过程 示例 1 输入{1,2,3}, {4,5}, {6,7} 链表11 - 2 - 3 - 6 - 7 链表24 - 5 - 6 - 7 初始first 指向 1second 指向 4。第一次遍历first 和 second 分别遍历各自链表到达尾部后跳转到另一链表头部。第二次遍历first 和 second 在节点 6 相遇。输出{6,7}。 示例 2 输入{1}, {2,3}, {} 链表11 链表22 - 3 初始first 指向 1second 指向 2。第一次遍历first 遍历到尾部后跳转到链表2头部second 遍历到尾部后跳转到链表1头部。第二次遍历first 和 second 均到达尾部NULL。输出{}。 总结 双指针法通过交替遍历链表保证了时间复杂度 O ( n m ) O(n m) O(nm)且额外空间复杂度为 O ( 1 ) O(1) O(1)。代码简单高效能够准确找到第一个公共节点或判定无公共节点。 备注 最开始我写的代码是这样的 while (first!second) {if(first-nex!NULL)first first-next;else first pHead2;if(second-next!NULL)second second-next;else second pHead1;}结果发现有问题如果两个不相交的链表改成下面的才正确 while (first!second) {if(first-next!NULL)first first-next;else first pHead2;if(second-next!NULL)second second-next;else second pHead1;}思考了下原因原来是如果按照旧的代码 if(first-next!NULL)那么说明当前是队尾使用 first first-next;相当于第一个把第二个连起来了两个队列相互首位相连原本不 else first pHead2;
http://www.hkea.cn/news/14453619/

相关文章:

  • 无障碍环境建设 网站网站建设mfdos
  • 城阳区城市规划建设局网站阿里云建网站步骤
  • 个人网站设计开题报告南川集团网站建设
  • 工业和信息化部五系网站建设wordpress opencart
  • 苏州市建设职业培训中心网站网站开发html文件规范
  • 软件正版化情况及网站建设情况网站建设与O2O的应用
  • 网站建设经费预算包括哪些wordpress eaccelerator
  • 网站域名注册如何填写广告投放平台投放
  • 网站备案流程以及所需资料wordpress您的密码重设链接无效
  • 自己做资讯网站海珠电子商务网站建设
  • wordpress增加边栏如何优化网络
  • 电子产品去什么网站做站点公司都是自己制作网站
  • 深圳住建设局网站公租房网站验收指标
  • 2019做网站图片用什么格式html国庆节网页制作代码
  • 深圳东莞网站开发石家庄最新新闻
  • 网站的设计与维护摘要宝安建网站公司
  • 网站可以做章子吗如何设计营销型网站建设
  • 十大素材网站宁波网站建设58同城
  • 档案安全网站安全建设男女直接做那个的视频网站
  • 专业的建设机械网站织梦网站怎么修改内容
  • 网站排版的优点静态摄影网站模板
  • 网站建设后续需要维护网站建设运营方案 团队
  • 国土资源局加强网站建设南昌网站设计哪个最好
  • 使用php如何做购物网站wordpress 副标题
  • 北京手机网站建设报价明年开春有望摘口罩
  • 怎么选择做网站的公司地图网站开发
  • 书籍网站设计wordpress 加描述 2017
  • 福州专业网站设计团队网站开发外包业务怎么接
  • 网站域名和网站网址吗潍坊做网站的那家好
  • 做糕点哪个网站网站链接维护怎么做