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;

        
    }
}
相关推荐
Coder_Boy_4 分钟前
Deeplearning4j+ Spring Boot 电商用户复购预测案例
java·人工智能·spring boot·后端·spring
踢足球092911 分钟前
寒假打卡:2026-2-7
java·开发语言·javascript
闻哥14 分钟前
Kafka高吞吐量核心揭秘:四大技术架构深度解析
java·jvm·面试·kafka·rabbitmq·springboot
金牌归来发现妻女流落街头16 分钟前
【Springboot基础开发】
java·spring boot·后端
考琪32 分钟前
Nginx打印变量到log方法
java·运维·nginx
wangjialelele43 分钟前
Linux中的进程管理
java·linux·服务器·c语言·c++·个人开发
历程里程碑44 分钟前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse
sin_hielo1 小时前
leetcode 1653
数据结构·算法·leetcode
李日灐1 小时前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
晔子yy1 小时前
如何设计让你的程序同时处理10w条数据
java