Go语言每日一练——链表篇(八)

传送门

牛客面试笔试必刷101题 ----------------两个链表的第一个公共结点

题目以及解析

题目

解题代码及解析

解析

这一道题使用的还是双指针算法,我们先求出两个链表的长度差n,然后定义快慢指针,让快指针先走n步,最后快慢指针在同一点,该店就是我们的目标点

代码

go 复制代码
package main
import( 
    . "nc_tools"
)
/*
 * type ListNode struct{
 *   Val int
 *   Next *ListNode
 * }
 */

/**
 * 
 * @param pHead1 ListNode类 
 * @param pHead2 ListNode类 
 * @return ListNode类
*/

func abs(a,b int) int{
    if a>b{
        return a-b
    }else{
        return b-a
    }
}

func FindFirstCommonNode( pHead1 *ListNode ,  pHead2 *ListNode ) *ListNode {
    l1,l2:=0,0
    dump,temp:=pHead1,pHead2
    for dump!=nil{
        dump=dump.Next
        l1++
    }
    for temp!=nil{
        temp=temp.Next
        l2++
    }
    var fast,slow *ListNode
    if l1>l2{
        fast,slow=pHead1,pHead2
    }else{
         fast,slow=pHead1,pHead2
    }
    for i:=0;i<abs(l1,l2);i++{
        fast=fast.Next
    }
    for fast!=nil{
        if fast!=slow{
            fast=fast.Next
            slow=slow.Next
        }else{
            break
        }
    }
    return slow
}

总结:

这题依旧是一道链表题,但是它很好的体现双指针思想的引用,大家可以简单的思考一下,用这道题来作为双指针算法的练手题

相关推荐
巨龙之路6 分钟前
Lua中的元表
java·开发语言·lua
徐行11020 分钟前
C++核心机制-this 指针传递与内存布局分析
开发语言·c++
序属秋秋秋31 分钟前
算法基础_数据结构【单链表 + 双链表 + 栈 + 队列 + 单调栈 + 单调队列】
c语言·数据结构·c++·算法
划水哥~34 分钟前
Kotlin作用域函数
开发语言·kotlin
小臭希35 分钟前
python蓝桥杯备赛常用算法模板
开发语言·python·蓝桥杯
mosaicwang41 分钟前
dnf install openssl失败的原因和解决办法
linux·运维·开发语言·python
apcipot_rain1 小时前
【密码学——基础理论与应用】李子臣编著 第五章 序列密码 课后习题
算法·密码学
不要不开心了1 小时前
sparkcore编程算子
pytorch·分布式·算法·pygame
88号技师2 小时前
【2024年最新IEEE Trans】模糊斜率熵Fuzzy Slope entropy及5种多尺度,应用于状态识别、故障诊断!
人工智能·算法·matlab·时序分析·故障诊断·信息熵·特征提取
清同趣科研2 小时前
R绘图|6种NMDS(非度量多维分析)绘图保姆级模板——NMDS从原理到绘图,看师兄这篇教程就够了
人工智能·算法