1669. 合并两个链表

1669. 合并两个链表

題解:
模拟链表操作

/**
 * 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 ListNode mergeInBetween(ListNode list1, int a, int b, ListNode list2) {
        int i = 0;
        ListNode head = new ListNode(-1, list1);
        ListNode index = list1;
        ListNode right = null;
        ListNode left = null;
        // 拿到删除始节点的前一个节点
        while (i < a - 1 && index != null) {
            index = index.next;
            i++;
        }
        left = index;
        if (a == 0) head.next = list2;
        // 拿到删除末节点的后一个节点
        while (i < b + 1 && index != null) {
            index = index.next;
            i++;
        }
        right = index;
        // 拼接
        left.next = list2;
        while (list2.next != null) {
            list2 = list2.next;
        }
        list2.next = right;
        // 返回开头
        return head.next;
    }
}
posted @   Eiffelzero  阅读(14)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
点击右上角即可分享
微信分享提示