2026年--Lc334-2130. 链表最大孪生和(链表转数组)--java版

1.题目


2.思路

链表转数组

(1)遍历链表,把所有节点值放进 ArrayList。

(2)n = size,只遍历前半段 i = 0 ... n/2-1

(3)计算每对 arr[i] + arr[n-1-i],维护最大值。

Java 里 ArrayList 不能用 list[i] 这种数组下标访问,要用list.get(i)去取元素

3.代码实现

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 int pairSum(ListNode head) {
        ArrayList<Integer> list=new ArrayList<>();
        while(head!=null)
        {
            list.add(head.val);
            head=head.next;
        }
        int n=list.size();
        int m=n/2;
        int sum=0;
        for(int i=0;i<m;i++)
        {
          sum=Math.max(sum,list.get(i)+list.get(n-i-1));
        }
        return sum;

        
    }
}
相关推荐
凤山老林8 分钟前
04-Java JDK, JRE和JVM
java·开发语言·jvm
camellias_6 小时前
【无标题】
java·tomcat
咸鱼2.07 小时前
【java入门到放弃】需要背诵
java·开发语言
澈2077 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
椰猫子7 小时前
Java:异常(exception)
java·开发语言
ambition202427 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
代码旅人ing7 小时前
链表算法刷题指南
数据结构·算法·链表
win x8 小时前
Redis 使用~如何在Java中连接使用redis
java·数据库·redis
星晨雪海8 小时前
基于 @Resource 的支付 Service 多实现类完整示例
java·开发语言
阿维的博客日记8 小时前
什么是逃逸分析
java·juc