当前位置: 首页 > 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/14495658/

相关文章:

  • 郴州网站建设价格免费建设微网站制作
  • 国外营销型网站wordpress后台演示
  • 泰康人寿网站如何做计划领取做cpa一定要有网站
  • 在线crm网站crm软件管理系统
  • 长沙网站推广排名优化咸阳seo培训
  • 个人网站建设流程 域名注册的选择网站模板源码免费下载
  • 做网站怎么别人搜不出来品牌建设途径
  • 郑州制作企业网站做棋牌网站团队
  • seo技术网站建设专业做中文网站
  • 网站建设 管理商城网站如何做
  • 如何把自己做的网站 放在网上wordpress+万能搜索页
  • 可以免费浏览的网站公司网站优化软件
  • 做tcf法语听力题的网站手机如何建立网站平台
  • crm公司seo关键词排名优化是什么
  • 网站备案幕布psd服务器正常网站打不开
  • 商城网站微信支付接口申请流程网站界面设计原则
  • 怎么用代码做网站图文分销系统开发
  • 网站推广费用价格唐山哪里建筑工地最好
  • 做外贸可以在哪些网站注册网站优化搜索
  • 杭州网站提升排名如何制定会员营销方案
  • 网站模版建站云搜索引擎
  • 这是我自己做的网站吗网站建设伍金手指下拉8
  • 纯html静态网站wordpress所见即所得编辑器
  • 网站建设咨询电话企业型网站
  • 网站如果实现微信支付吗wordpress git主题
  • 女人与马做受网站wordpress需要懂什么
  • 网站设计费报价表金湖网站制作
  • qq号码提取网站宝安营销型网站制作
  • 寿光网站建设报价wordpress 自定义 文章形式
  • 舟山网站建设流程上海seo服务