Leetcode234.判断是否是回文单链表

题目描述

思路,把单链表转化为ArrayList,然后比较前后两个数是否相等。

java 复制代码
    class Solution {
        public boolean isPalindrome(ListNode head) {
            if (head == null) {
                return false;
            }
            List<Integer> valList = new ArrayList<Integer>();
            ListNode tmp = head;
            while (tmp != null) { 
                valList.add(tmp.val); //把单链表节点的数值,存储到ArrayList中,方便比较。
                tmp = tmp.next;
            }
            /**
             * 1. 只比较一半:(valList.size() - 1) / 2
             * 2. 小于等于
             */
            for (int i = 0; i <= (valList.size() - 1) / 2; i++) { //注意这里的小于等于
                if (valList.get(i) != valList.get(valList.size() - 1 - i)) {
                    return false;
                }
            }
            return true;
        }
    }

如果用双指针的写法,代码如下:

java 复制代码
        public boolean isPalindromeWithDoublePoint(ListNode head) {
            if (head == null) {
                return false;
            }
            List<Integer> valList = new ArrayList<Integer>();
            ListNode tmp = head;
            while (tmp != null) {
                valList.add(tmp.val); //把单链表节点的数值,存储到ArrayList中,方便比较。
                tmp = tmp.next;
            }

            int front = 0;
            int back = valList.size() - 1;
            while (front < back) {
                if (valList.get(front) != valList.get(back)) {
                    return false;
                }
                back--;
                front++;
            }
            return true;
        }
相关推荐
焜昱错眩..8 分钟前
力扣周赛难题 3906.统计网格路径中好整数的数目——自我拆解学习与分析(数位dp上下界的奇妙)
学习·算法·leetcode·动态规划
兰令水20 分钟前
topcode【随机算法题】【2026.5.14打卡-java版本】
java·算法·leetcode
小辉同志36 分钟前
72. 编辑距离
leetcode·多维动态规划
程序员陆业聪44 分钟前
DNS优化实战:从运营商DNS到HttpDNS的进化之路
android
程序员陆业聪1 小时前
连接优化与复用:让每一次握手都物超所值|Android网络优化系列(3)
android
z200509301 小时前
今日算法:617,合并二叉树
算法·leetcode
zhangphil1 小时前
Android Bitmap.Config.HARDWARE属性产生的来源和控制权
android
YF02112 小时前
深度解构Android OkDownload断点续传
android·数据库·okhttp
Co_Hui2 小时前
Android: Service基本使用
android
吃着火锅x唱着歌2 小时前
LeetCode 496.下一个更大元素I
算法·leetcode·职场和发展