当前位置: 首页 > article >正文

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

传送门

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

题目以及解析

题目

在这里插入图片描述

解题代码及解析

解析

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

代码

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
}

总结:

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


http://www.kler.cn/a/234274.html

相关文章:

  • 如何判定linux系统CPU的核心架构
  • #include<string>和#include<string.h>有什么区别
  • 马斯克万卡集群AI数据中心引发的科技涟漪:智算数据中心挑战与机遇的全景洞察
  • 山泽光纤HDMI线:铜线的隐藏力量
  • 微服务(二)
  • FatLab:我的编程课程系列
  • 深入了解Redis:选择适用于你的场景的持久化方案
  • IAR报错:Error[Pa045]: function “halUartInit“ has no prototype
  • JVM 性能调优- 五种内存溢出(5)
  • 006集——where语句进行属性筛选——arcgis
  • 从零开始:用 Rust 编写你的第一个 Web 服务
  • python web 框架Django学习笔记
  • 服务器渲染(SSR)-前端框架
  • 前端架构: 脚手架开发流程中的难点梳理
  • 5G NR 频率计算
  • Maven进阶
  • 与AI对话:编写高效Prompt的指南
  • mysql8.0 正值表达式Regular expressions (sample database classicmodels _No.5)
  • 跳过mysql8.0密码重置密码 Shell脚本
  • 开源项目的三年,我的项目经历了哪些变化?
  • 9、Node.js的下载与安装配置
  • 2023年,跳槽了4家电源公司
  • 专业135+总400+中国科学院大学859国科大信号与系统考研经验电子信息与通信,真题,大纲,参考书
  • 【Linux】学习-动静态库
  • 什么是Python中的上下文管理器(Context Managers)?with语句是如何工作的?请解释Python中的装饰器如何用于实现函数缓存。
  • 创新指南|企业实施Gen AI面临的10大挑战