题解 | #判断一个链表是否为回文结构#

判断一个链表是否为回文结构

https://www.nowcoder.com/practice/3fed228444e740c8be66232ce8b87c2f

判断一个链表是否为回文结构

一开始我的思路是,将整个链表反转,但修改了半天代码依然出现报错问题,没有办法只能看了看大佬的解题思路,利用了快慢指针找到中间节点,再反转中间节点后面的链表,在跟原链表进行比较,如果值都相等,则为回文结构,代码如下:

  public boolean isPail (ListNode head) {
        // write code here
        ListNode fast = head;//快指针
        ListNode slow = head;//慢指针
        while (fast!=null&&fast.next!=null){
            fast=fast.next.next;
            slow=slow.next;
        }
//这里fast为空则说明链表长度为单数,需要将slow。next定为反转节点
        if (fast!=null){
            slow=slow.next;
        }
//反转链表
        slow=ReverseList(slow);
        fast=head;
        while (slow!=null){
            if (fast.val!=slow.val){//比较反转后两链表的值
                return false;
            }else {
                fast=fast.next;
                slow=slow.next;
            }
        }
        return true;
    }

这里是反转链表的代码

 public ListNode ReverseList(ListNode head) {
        ListNode pre = null;
        ListNode cur = head;
        while (cur != null) {
            ListNode CurNext = cur.next;
            cur.next = pre;
            pre = cur;
            cur = CurNext;
        }
        return pre;
    }
以上




全部评论

相关推荐

02-22 18:38
门头沟学院 Java
程序员牛肉:标准的NPC简历,一个短链接+12306。你可以在牛客上面搜一搜有多少人的简历和你一样。你自己能不能给出你一个理由让面试官在大家简历高度相同的情况下,选择约面你而不是对应的211,985学生? 是因为你即将拥有的那段小厂实习吗?这种小厂实习真的很有含金量吗?因此你可以找实习,但是你如果只能找到小厂实习的话,其实意义不太大。 但你的时间是充足的,相信我:从现在到今年的九月份大三上你就干两个事情:"写博客"+“参加开源之夏”。这两个搞好了不亚于一段大厂实习的含金量。 想要让自己变得更强,首先就是不要把自己当打工人看待,让自己简历上面的活人气息更多一点,不要让自己成为流水线的产物。你不是在出售你的技能,你是在利用你的技能和公司达成一种合作关系。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务