链表的返回中点问题

public class test9 {
    // 定义一个内部类Node,表示链表的节点
    public static class Node{
        public int value; // 节点的值
        public Node next; // 指向下一个节点的引用

        // 构造函数,用于创建一个新的节点并初始化其值
        public Node(int v){
            value = v;
        }
    }

    // 奇数长度返回中点,偶数长度返回上中点
    public static Node midOrUpMidNode(Node head){
        if(head == null || head.next ==null || head.next.next ==null){
            return head; // 如果链表为空或只有一个或两个节点,直接返回头节点
        }
        Node slow = head.next; // 慢指针从第二个节点开始
        Node fast = head.next.next; // 快指针从第三个节点开始
        while(fast.next != null && fast.next.next != null){
            slow = slow.next; // 慢指针每次移动一步
            fast = fast.next.next; // 快指针每次移动两步
        }
        return slow; // 当快指针到达链表末尾时,慢指针所在位置即为中点或上中点
    }

    // 奇数长度返回中点,偶数长度返回下中点
    public static Node midOrDownMidNode(Node head){
        if(head == null || head.next ==null ){
            return head; // 如果链表为空或只有一个节点,直接返回头节点
        }
        Node slow = head.next; // 慢指针从第二个节点开始
        Node fast = head.next; // 快指针从第二个节点开始
        while(fast.next != null && fast.next.next != null){
            slow = slow.next; // 慢指针每次移动一步
            fast = fast.next.next; // 快指针每次移动两步
        }
        return slow;
 // 当快指针到达链表末尾时,慢指针所在位置即为中点或下中点
    }

    // 奇数长度返回中点前一个,偶数长度返回上中点前一个
    public static Node midOrUpMidPreNode(Node head){
        if(head == null || head.next ==null || head.next.next ==null){
            return null; // 如果链表为空或只有一个或两个节点,没有中点前一个节点,返回null
        }
        Node slow = head; // 慢指针从头节点开始
        Node fast = head.next.next; // 快指针从第三个节点开始
        while(fast.next != null && fast.next.next != null){
            slow  = slow.next; // 慢指针每次移动一步
            fast = fast.next.next; // 快指针每次移动两步
        }
        return slow; 
// 当快指针到达链表末尾时,慢指针所在位置的前一个节点即为中点前一个或上中点前一个
    }

    // 奇数长度返回中点前一个,偶数长度返回下中点前一个
    public static Node midOrDownMidPreNode(Node head){
        if(head == null || head.next ==null ){
            return null; // 如果链表为空或只有一个节点,没有中点前一个节点,返回null
        }
        if(head.next.next == null){
            return head; // 如果链表只有两个节点,返回头节点作为下中点前一个节点
        }
        Node slow = head; // 慢指针从头节点开始
        Node fast = head.next; // 快指针从第二个节点开始
        while(fast.next != null && fast.next.next != null){
            slow = slow.next; // 慢指针每次移动一步
            fast = fast.next.next; // 快指针每次移动两步
        }
        return slow; 
// 当快指针到达链表末尾时,慢指针所在位置的前一个节点即为中点前一个或下中点前一个
    }
}

相关推荐

  1. 返回问题

    2024-07-21 23:02:02       22 阅读
  2. 数据结构习题--返回

    2024-07-21 23:02:02       29 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-21 23:02:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-21 23:02:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-21 23:02:02       58 阅读
  4. Python语言-面向对象

    2024-07-21 23:02:02       69 阅读

热门阅读

  1. python实战(输出会动的爱心)*

    2024-07-21 23:02:02       19 阅读
  2. 42、PHP 实现把二叉树打印成多行

    2024-07-21 23:02:02       19 阅读
  3. 防范缓冲区溢出攻击的方法

    2024-07-21 23:02:02       19 阅读
  4. 【如何使用Python编程】

    2024-07-21 23:02:02       23 阅读
  5. 【Python中的列表是什么】

    2024-07-21 23:02:02       24 阅读