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

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

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

思路,链表反转后逐一比较

注意的是:链表不能直接反转,否则结构发生变化,需要新复制一个链表进行操作

import java.util.*;
public class Solution {
    //反转链表指针
    ListNode reverse(ListNode head) { //反转链表,链表结构会发生变化
        //前序节点
        ListNode prev = null;
        while(head != null){
            //断开后序
            ListNode next = head.next; 
            //指向前序
            head.next = prev; 
            prev = head;
            head = next;
        }
        return prev;
    }
    
     public boolean isPail(ListNode head) {
        ListNode dummyHead = new ListNode(-1);//定义一个新链表
        //copy orgin list to p1
        ListNode p1 = dummyHead;
        ListNode p2 = head;
        while (p2 != null) {//将链表复制给新链表,不能动原链表
            p1.next = new ListNode(p2.val);
            p2 = p2.next;
            p1 = p1.next;
        }
        //traverse the orgin list and reversed list
        p1 = dummyHead.next;
        p2 = reverse(head);
        while (p1 != null ) {
            if (p1.val != p2.val) {
                return false;
            }
            p1 = p1.next;
            p2 = p2.next;
        }
        return true;
    }
}





全部评论

相关推荐

11-28 16:00
已编辑
武汉理工大学 Java
Tom哥981:这份简历是“短期项目硬堆中大型系统技术”的“技术炫技式造假模板”,槽点密集到能当反面教材: ### 1. 「项目时长」和「技术密度」严重脱节,造假痕迹焊死在简历上 两个项目时长分别是**3个月、2个月**,但堆了Spring AI、Elasticsearch、MinIO、Kafka、ShardingSphere、Docker、Sentinel等近20个中大型项目才用的技术——正常情况下,光把这些中间件的文档看完+环境搭好,3个月都不够,更别说实现“AI多轮对话、分库分表、RBAC权限、大模型调用”这些功能。 说白了:你这不是“做项目”,是把“后端技术栈清单”往项目里硬塞,明摆着“只调用了API,没碰过核心逻辑”。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务