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;

        
    }
}
相关推荐
一个爱编程的人5 分钟前
一个数是不是素数
数据结构·算法
Hui_AI7209 分钟前
基于RAG的农产品GEO溯源智能问答系统实现
开发语言·网络·人工智能·python·算法·创业创新
lwf00616410 分钟前
FFM (Field-aware Factorization Machine) 学习日记
算法·机器学习
南宫萧幕11 分钟前
HEV能量管理控制算法实战:从MPC/RL理论基础到Simulink闭环建模
算法·matlab·汽车·控制·pid
IT猿手17 分钟前
SCI一区:章鱼优化算法(Octopus Optimization Algorithm, OOA)求解23个测试函数,出图丰富,提供完整MATLAB代码
开发语言·算法·matlab
superior tigre18 分钟前
739 每日温度
算法·leetcode·职场和发展
忡黑梨22 分钟前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
Run_Teenage37 分钟前
算法:离散化模板
算法
乐迪信息37 分钟前
乐迪信息:实时预警,秒级响应:船舶AI异常行为检测算法
大数据·人工智能·算法·安全·目标跟踪
6Hzlia40 分钟前
【Hot 100 刷题计划】 LeetCode 15. 三数之和 | C++ 排序+双指针
c++·算法·leetcode