LeetCode 回文链表

这里有用到关于List集合的知识,可看上一篇Java 数组与集合(List, Set, Map)获取长度与遍历操作

解题方法:先将链表存储到动态数组中,然后使用两个指针一头一尾进行遍历操作进行比较

注意:使用equals判断相等,因为链表使用的是Integer类型

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public boolean isPalindrome(ListNode head) {
        //将链表的值复制到数组中
        List<Integer> array=new ArrayList<Integer>();
        ListNode p=head;
        for(;p!=null;p=p.next){
            array.add(p.val);
        }
        // 双指针法判断
        int first=0;
        int last=array.size()-1;
        while(first<=last){
            if(!array.get(first).equals(array.get(last))){
                return false;
            }
            first++;
            last--;
        }
        return true;

        
    }
}
相关推荐
CSDN_RTKLIB17 小时前
【std::map】与std::unordered_map差异
算法·stl·哈希算法
FL1717131417 小时前
Geometric Control
人工智能·算法
老鼠只爱大米17 小时前
LeetCode算法题详解 283:移动零
算法·leetcode·双指针·快慢指针·移动零·move zeroes
过河卒_zh156676617 小时前
喜讯:第十五批生成合成类算法备案备案号公布
人工智能·算法·aigc·生成式人工智能·算法备案
cpp_250117 小时前
B3927 [GESP202312 四级] 小杨的字典
数据结构·c++·算法·题解·洛谷
踩坑记录17 小时前
leetcode hot100 最长连续子序列 哈希表 medium
leetcode
Cx330❀17 小时前
《C++ 递归、搜索与回溯》第2-3题:合并两个有序链表,反转链表
开发语言·数据结构·c++·算法·链表·面试
AI科技星17 小时前
电磁耦合常数Z‘的第一性原理推导与严格验证:张祥前统一场论的几何基石
服务器·人工智能·线性代数·算法·矩阵
独自破碎E17 小时前
链表相加(二)
数据结构·链表