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;

        
    }
}
相关推荐
初次攀爬者15 分钟前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺20 分钟前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart2 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP3 小时前
MyBatis-mybatis入门与增删改查
java
孟陬6 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌6 小时前
一站式了解四种限流算法
java·后端·go
华仔啊6 小时前
Java 开发千万别给布尔变量加 is 前缀!很容易背锅
java
也些宝7 小时前
Java单例模式:饿汉、懒汉、DCL三种实现及最佳实践
java
Nyarlathotep01138 小时前
SpringBoot Starter的用法以及原理
java·spring boot