算法6:相交链表

题目链接

解析:

完整代码:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
typedef struct ListNode ListNode;
class Solution {
public:
    ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
        //1.两个链表的长度
       ListNode* pa = headA;
       ListNode* pb = headB;
       int sizeA = 0, sizeB =0;
       while(pa)
       {
        ++sizeA;
        pa = pa ->next;
       } 
        while(pb)
       {
        ++sizeB;
        pb = pb ->next;
       } 
       int gap = abs(sizeA - sizeB);
       ListNode* longlist = headA;
       ListNode* shortlist = headB;
       if(sizeA < sizeB)
       {
        longlist = headB;
        shortlist = headA;
       }
       while(gap--)
       {
        //让长链表先走
        longlist = longlist->next;
       }
       while(longlist)
       {
        if(longlist == shortlist)
            return longlist;   //shortlist
        longlist = longlist ->next;
        shortlist = shortlist ->next;
       }
       //跳出循环,两个链表不相等
       return NULL;
        
    }
};
相关推荐
计算机安禾几秒前
【数据库系统原理】第14篇:关系模式的语义约束:函数依赖的公理系统与闭包计算
人工智能·算法·机器学习
量化君也2 分钟前
快速入门量化交易都要学些什么?
大数据·人工智能·python·算法·金融
AbandonForce12 分钟前
滑动窗口:定长滑动窗口与不定长滑动窗口
数据结构·c++·算法
炸薯条!25 分钟前
二叉树的链式表示(2)
java·数据结构·算法
Tairitsu_H28 分钟前
[LC优选算法#2] 滑动窗口 | 长度最小的子数组 | 无重复字符的最长子串 | 最大连续1的个数
算法
小欣加油29 分钟前
leetcode3689最大子数组总值I
c++·算法·leetcode·职场和发展·贪心算法
下午写HelloWorld37 分钟前
【概念与应用】轻量级加密算法LEA、动态脱敏算法DDA、零知识证明ZKP和优化协同交互协议OCIP
算法·区块链·密码学·安全架构·零知识证明
飞舞哲1 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab
YHHLAI1 小时前
JavaScript 数据结构精讲:数组底层与实战避坑
开发语言·javascript·数据结构
Coder-magician1 小时前
《代码随想录》刷题打卡day12:二叉树part02
数据结构·c++·算法