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
}

总结:

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

相关推荐
乐迪信息1 天前
乐迪信息解决港口船型识别难题!AI算法盒子检测船舶类型
人工智能·算法·智能电视
小杍随笔1 天前
【Rust Cargo 目录迁移到 D 盘:不改变安装路径和环境变量的终极方案】
开发语言·后端·rust
梭七y1 天前
【力扣hot100题】(151)课程表
算法·leetcode·哈希算法
Henry Zhu1231 天前
Qt Model/View架构详解(五):综合实战项目
开发语言·qt·架构
孞㐑¥1 天前
算法—滑动窗口
开发语言·c++·经验分享·笔记·算法
历程里程碑1 天前
Linux 3 指令(3):进阶指令:文件查看、资源管理、搜索打包压缩详解
linux·运维·服务器·c语言·数据结构·笔记·算法
AI-小柒1 天前
从零入门大语言模型(LLM):系统学习路线与实践指南
大数据·开发语言·人工智能·学习·信息可视化·语言模型·自然语言处理
hhy_smile1 天前
Python environment and installation
开发语言·python
戌中横1 天前
JavaScript 对象
java·开发语言·javascript
crossaspeed1 天前
面向对象的三大特征和反射(八股)
java·开发语言