栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

剑指offer

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

剑指offer

题目:

给定一个链表的 头节点 head ,请判断其是否为回文链表。

如果一个链表是回文,那么链表节点序列从前往后看和从后往前看是相同的。

示例 1:

输入: head = [1,2,3,3,2,1]
输出: true

示例 2:

输入: head = [1,2]
输出: false

提示:

链表 L 的长度范围为 [1, 105]
0 <= node.val <= 9

代码一:利用线性表 + 双指针 O(n) O(n) 
package jianzhioffer;

import java.util.ArrayList;
import java.util.List;

public class offer_27 {
    public static void main(String[] args) {
        linkList list = new linkList();

        ListNode node1 = new ListNode(1);
        ListNode node2 = new ListNode(2);
        ListNode node3 = new ListNode(3);
        ListNode node4 = new ListNode(4);
        ListNode node5 = new ListNode(3);
        ListNode node6 = new ListNode(2);
        ListNode node7 = new ListNode(1);

        list.add(node1);
        list.add(node2);
        list.add(node3);
        list.add(node4);
        list.add(node5);
        list.add(node6);
        list.add(node7);

        System.out.println(isPalindrome(node1));
    }

    public static boolean isPalindrome(ListNode head) {
        ListNode temp = head;
        List list = new ArrayList<>();
        // 把节点添加到线性表
        while (temp != null) {
            list.add(temp.val);
            temp = temp.next;
        }
        int i = 0;
        int j = list.size() - 1;
        while (i < j) {
            if (list.get(i) != list.get(j)) {
                return false;
            }
            i++;
            j--;
        }
        return true;
    }

    static class ListNode {
        int val;
        ListNode next;
        ListNode (int x) {
            val = x;
            next = null;
        }

        public ListNode(int val, ListNode next) {
            this.val = val;
            this.next = next;
        }
    }

    
    static class linkList {
        ListNode head = new ListNode(0);
        
        public void add(ListNode node) {
            ListNode temp = head;
            while (true) {
                if (temp.next == null) {
                    break;
                }
                temp = temp.next;
            }
            temp.next = node;
        }
    }
}
 代码二:寻找中间节点 + 反转链表 + 双指针 O(N) O(1)

import java.util.ArrayList;
import java.util.List;

public class Test {
    public static void main(String[] args) {
        linkList list = new linkList();

        ListNode node1 = new ListNode(1);
        ListNode node2 = new ListNode(2);
        ListNode node3 = new ListNode(3);
        ListNode node4 = new ListNode(4);
        ListNode node5 = new ListNode(3);
        ListNode node6 = new ListNode(2);
        ListNode node7 = new ListNode(1);

        list.add(node1);
        list.add(node2);
        list.add(node3);
        list.add(node4);
        list.add(node5);
        list.add(node6);
        list.add(node7);

        System.out.println(isPalindrome(node1));
    }

    public static boolean isPalindrome(ListNode head) {
        // 寻找中间节点并把后半段链表反转
        ListNode mid = midNode(head);
        ListNode l2 = reverse(mid.next);

        boolean res = true;

        // 判断是否回文
        while (res && l2 != null) {
            if (head.val != l2.val) {
                res = false;
            }
            head = head.next;
            l2 = l2.next;
        }
        // 记得还原链表,虽然本题并没有要求还原链表,
        // 但是在实际开发中,不能因为判断是否回文就随意更改链表的结构。
        mid.next = reverse(l2);
        return res;
    }

    // 寻找中间节点
    public static ListNode midNode(ListNode head) {
        ListNode slow = head;
        ListNode fast = head;
        while (fast.next != null && fast.next.next != null) {
            slow = slow.next;
            fast = fast.next.next;
        }
        return slow;
    }

    // 反转链表
    public static ListNode reverse (ListNode head) {
        ListNode res = head;
        ListNode nextTemp = null;
        ListNode temp = null;
        while (res != null) {
            nextTemp = res.next;
            res.next = temp;
            temp = res;
            res = nextTemp;
        }
        return temp;
    }

    static class ListNode {
        int val;
        ListNode next;
        ListNode (int x) {
            val = x;
            next = null;
        }

        public ListNode(int val, ListNode next) {
            this.val = val;
            this.next = next;
        }
    }

    
    static class linkList {
        ListNode head = new ListNode(0);
        
        public void add(ListNode node) {
            ListNode temp = head;
            while (true) {
                if (temp.next == null) {
                    break;
                }
                temp = temp.next;
            }
            temp.next = node;
        }
    }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/695094.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号