C语言每日一题:12《数据结构》相交链表。

题目:


题目链接

思路一:

1.如果最后一个节点相同说明一定有交点。

2.使用两个循环获取一下长度,同时可以获取到尾节点。

3。注意初始化lenA和lenB为1,判断下一个节点是空是可以保留尾节点的。长度会少一个,尾节点没有进入循环就不会++;

(保留位节点是判断是否链表相交);

4.计算长度差的绝对值,因为不知道谁大谁小。

5.假设一个长一个短,并且定义名称代表长度的新的链表头。

6.判断+修正

7.进行长的先走差距步。

8.如果出现最后一个才相交的情况那么循环走到两个链表的节点都走到空才可以结束保证最后一个节点是被判断的。

注意(循环遍历不要动参数)

c 复制代码
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {

    struct ListNode* curA=headA,*curB=headB;
    struct ListNode* tileA=headA,*tileB=headB;
    int lenA=1,lenB=1;

    while(tileA->next)
    {
        tileA=tileA->next;
        lenA++;
    }
    while(tileB->next)
    {
        tileB=tileB->next;
        lenB++;
    }

    if(tileA!=tileB)
    {
        //说明没有相交
        return NULL;
    }
    //说明一定相交
    int gap=abs(lenA-lenB);

    //2.谁比较大就先走差距步
    //假设
    struct ListNode* shortlist=headA,*longlist=headB;
    if(lenB<lenA)
    {
        //修正
        shortlist=headB;
        longlist=headA;
    }

    //长的先走差距补。
    while(gap--)
    {
        longlist=longlist->next;
    }

    while(shortlist&&longlist)
    {
        if(shortlist==longlist)
        {
            return longlist;
        }
        else
        {
            shortlist=shortlist->next;
            longlist=longlist->next;
        }
    }
    return NULL;
}
相关推荐
少司府19 小时前
C++基础入门:深挖list的那些事
开发语言·数据结构·c++·容器·list·类型转换·类和对象
罗超驿19 小时前
14.MySQL索引底层原理:从数据结构到B+树的深度解析
数据结构·b树·mysql
孬甭_19 小时前
单链表详解
c语言·数据结构
张二娃同学19 小时前
02_C语言数据类型_整型浮点型字符型一次讲清楚
android·java·c语言
鱼子星_19 小时前
【数据结构与算法】数据结构基础——栈和队列
c语言·数据结构
一枝小雨19 小时前
什么是标准C函数:以RISC-V架构下的C函数为例
c语言·risc-v·内核原理
承渊政道19 小时前
【贪心算法】(经典实战应用解析(三):K次取反后最⼤化的数组和、按⾝⾼排序、优势洗牌、最⻓回⽂串、增减字符串匹配)
数据结构·c++·学习·算法·贪心算法·线性回归·哈希算法
三品吉他手会点灯19 小时前
C语言学习笔记 - 34.数据类型 - 编程规范与高效学习方法
c语言·开发语言·笔记·学习
Lucky_ldy19 小时前
C语言学习:动态内存管理(数据结构关键)
c语言·数据结构·学习
JackSparrow41420 小时前
彻底理解Java NIO(二)C语言实现 I/O多路复用+Reactor模式 服务器详解
java·linux·c语言·后端·nio·reactor模式