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

双指针 -876. 链表的中间结点-leetcode

开始一个专栏,写自己的博客

双指针,也算是作为自己的笔记吧!


双指针从广义上来说,是指用两个变量在线性结构上遍历而解决的问题。狭义上说,

  • 对于数组,指两个变量在数组上相向移动解决的问题;
  • 对于链表,指两个变量在链表上同向移动解决的问题,也称为「快慢指针」问题。

题库讨论交流


876. 链表的中间结点 - 力扣(Leetcode)

目录

方法一

方法二.滑动窗口


方法一

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode middleNode(ListNode head) {
        ListNode p=head;
        int len=0;
        while(p!=null){
            len++;
            p=p.next;
        }
        ListNode list=head;
        for(int i=0;i<len/2;i++){
            list=list.next;
        }
        return list;
    }
}

从实例中可以发现,当有五个元素的时候,返回会以第(int)5/2个节点作为头结点;当有六个元素的时候,返回会以6/2个节点作为头结点。

所以,无论链表元素个数是奇数个还是偶数个都一样。

先计算出链表一共有多少个节点,然后将第len/2个节点作为头结点返回即可。

方法二.滑动窗口

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode middleNode(ListNode head) {
        ListNode fast=head;
        ListNode slow=head;
        while(fast!=null&&fast.next!=null){
            slow=slow.next;
            fast=fast.next.next;
        }
        return slow;
    }
}

从图中可以看出,当链表节点元素有五个的时候,需要返回的是第三个节点作为头节点,所以最终要返回的是指向第三个结点的那个指针。

在这个有五个节点的链表中,两个指针分别进行了三次移动。

每一次slow指针往后移动一位,fast指针往后移动二位,当fast==null||fast.next==null时,两个指针停止移动,这时,返回slow所指向的节点。


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

相关文章:

  • 美摄科技为企业打造专属PC端视频编辑私有化部署方案
  • Vue语音播报功能
  • 互斥与同步
  • 优先级队列(算法十四)
  • 使用gtsam添加OrientedPlane3Factor平面约束因子
  • 计算机网络 (39)TCP的运输连接管理
  • 【面试题系列】K8S常见面试题
  • 【vue.js】在网页中实现一个金属抛光质感的按钮
  • 有关pytorch的一些总结
  • 今年还能学java么?
  • 面试阿里测开岗失败后,被面试官在朋友圈吐槽了......
  • 多线程案例——阻塞队列
  • HTTP详解
  • 15000 字的 SQL 语句大全 第一部分
  • C语言格式和注意点
  • Redis知识点汇总
  • <Linux>计算机体系结构和操作系统
  • 我一个女孩子居然做了十年硬件……
  • Qss样式表语法
  • JavaScript 库
  • 数影周报:SpaceX设计图纸被泄露,拍明芯城正式在纳斯达克上市
  • 【YOLOv8/YOLOv7/YOLOv5/YOLOv4/Faster-rcnn系列算法改进NO.60】损失函数改进为wiou
  • 计算机网络的基本组成
  • 【笔试强训选择题】Day3.习题(错题)解析
  • 什么是PCB走线的3W原则
  • 用ChatGPT编写的一个调用ElasticSearch的maven的spring elasticsearch demo案例