首页 最新 热门 推荐

  • 首页
  • 最新
  • 热门
  • 推荐

【每日一题】牛客网——链表的回文结构

  • 24-03-17 21:10
  • 4610
  • 7207
blog.csdn.net

在这里插入图片描述

✨专栏:《Java SE语法》 | 《数据结构与算法》 | 《C生万物》

❤️感谢大家点赞??收藏⭐评论✍?,您的三连就是我持续更新的动力❤️

?小杨水平有限,欢迎各位大佬指点,相互学习进步!


文章目录

  • 1. 题目描述
    • 测试样例:
  • 2. 思路
  • 3. 代码

1. 题目描述

对于一个链表,请设计一个时间复杂度为O(n),额外空间复杂度为O(1)的算法,判断其是否为回文结构。

给定一个链表的头指针A,请返回一个bool值,代表其是否为回文结构。保证链表长度小于等于900。

测试样例:

输入:1->2->2->1

输出:true

题目链接?

2. 思路

  1. 判断链表是否为空,如果为空,那么链表就是回文的

  2. 找到中间元素

    1. 定义两个指针slow和fast,fast每次移动两步,slow每次移动一步,当fast走到链表中的最后一个节点是,slow就指向了链表的中间节点。

    image-20231221191717372

  3. 反转链表后半部分的元素

    1. 定义指针cur指向中间节点的next
    2. 从中间节点循环遍历链表
    3. 定义指针curNext指向cur的next(保存下一个节点)
    4. 将当前节点的next指向slow
    5. slow移动到当前节点的cur位置
    6. cur移动到下一个节点

    image-20231221195507479

  4. 同时遍历反转后的链表和原始链表的前半部分,并比较每个节点的值。如果所有的节点都匹配,那么链表就是回文;否则它不是回文。

    1. 一个从前一个从后循环遍历链表,直到相遇
    2. 判断两个当前节点是否相同,如果不同返回false
    3. 如果相同判断head的next等不等于slow,如果等于直接返回true(链表节点个数为偶数个)
    4. head移动到下一个节点
    5. slow移动到下一个节点

    image-20231221221213766

3. 代码

import java.util.*;

/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class PalindromeList {
    public boolean chkPalindrome(ListNode head) {
        if (head == null) {
            return true;
        }
        // write code here
        // 1.找到中间元素
        ListNode fast = head;
        ListNode slow = head;

        while (fast != null && fast.next != null) {
            fast = fast.next.next;
            slow = slow.next;
        }

        // 2.反转链表
        ListNode cur = slow.next;
        while (cur != null) {
            ListNode curNext = cur.next;
            cur.next = slow;
            slow = cur;
            cur = curNext;
        }

        // 3.一个向后遍历一个向前遍历
        while (slow != head) {
            if (slow.val != head.val) {
                return false;
            }
            if (head.next == slow) {
                return true;
            }
            head = head.next;
            slow = slow.next;
        }
        return true;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49

运行结果: image-20231221221355132
在这里插入图片描述

爱敲代码的小杨
微信公众号
记录学习过程,分享学习心得
注:本文转载自blog.csdn.net的爱敲代码的小杨.的文章"https://blog.csdn.net/QQ3447387928/article/details/136109982"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
复制链接
复制链接
相关推荐
发表评论
登录后才能发表评论和回复 注册

/ 登录

评论记录:

未查询到任何数据!
回复评论:

分类栏目

后端 (14832) 前端 (14280) 移动开发 (3760) 编程语言 (3851) Java (3904) Python (3298) 人工智能 (10119) AIGC (2810) 大数据 (3499) 数据库 (3945) 数据结构与算法 (3757) 音视频 (2669) 云原生 (3145) 云平台 (2965) 前沿技术 (2993) 开源 (2160) 小程序 (2860) 运维 (2533) 服务器 (2698) 操作系统 (2325) 硬件开发 (2491) 嵌入式 (2955) 微软技术 (2769) 软件工程 (2056) 测试 (2865) 网络空间安全 (2948) 网络与通信 (2797) 用户体验设计 (2592) 学习和成长 (2593) 搜索 (2744) 开发工具 (7108) 游戏 (2829) HarmonyOS (2935) 区块链 (2782) 数学 (3112) 3C硬件 (2759) 资讯 (2909) Android (4709) iOS (1850) 代码人生 (3043) 阅读 (2841)

热门文章

113
数据结构与算法
关于我们 隐私政策 免责声明 联系我们
Copyright © 2020-2025 蚁人论坛 (iYenn.com) All Rights Reserved.
Scroll to Top