当前位置: 首页 > article >正文

java练习(5)

ps:题目来自力扣

给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。

请你将两个数相加,并以相同形式返回一个表示和的链表。

你可以假设除了数字 0 之外,这两个数都不会以 0 开头。

class Solution {
    // 该方法用于将两个逆序存储数字的链表相加,并返回表示和的链表
    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        // 初始化结果链表的头节点和尾节点,初始值都为 null
        ListNode head = null, tail = null;
        // 用于记录进位,初始值为 0
        int carry = 0;

        // 只要 l1 或者 l2 还有节点,就继续进行相加操作
        while (l1 != null || l2 != null) {
            // 如果 l1 不为空,取其节点值,否则为 0
            int n1 = l1 != null ? l1.val : 0;
            // 如果 l2 不为空,取其节点值,否则为 0
            int n2 = l2 != null ? l2.val : 0;
            // 计算当前位的和,包括之前的进位
            int sum = n1 + n2 + carry;

            // 如果结果链表还没有头节点,说明是第一次创建节点
            if (head == null) {
                // 创建一个新节点,值为 sum 对 10 取余的结果
                // 同时将头节点和尾节点都指向这个新节点
                head = tail = new ListNode(sum % 10);
            } else {
                // 如果结果链表已经有头节点,创建一个新节点,值为 sum 对 10 取余的结果
                // 并将这个新节点连接到尾节点的后面
                tail.next = new ListNode(sum % 10);
                // 尾节点移动到新创建的节点
                tail = tail.next;
            }

            // 更新进位,sum 除以 10 的商作为新的进位
            carry = sum / 10;

            // 如果 l1 不为空,将 l1 指针移动到下一个节点
            if (l1 != null) {
                l1 = l1.next;
            }
            // 如果 l2 不为空,将 l2 指针移动到下一个节点
            if (l2 != null) {
                l2 = l2.next;
            }
        }

        // 当 l1 和 l2 都遍历完后,如果还有进位
        if (carry > 0) {
            // 创建一个新节点,值为进位的值
            // 并将这个新节点连接到尾节点的后面
            tail.next = new ListNode(carry);
        }

        // 返回结果链表的头节点
        return head;
    }
}

// 定义链表节点类
class ListNode {
    int val;
    ListNode next;
    // 无参构造函数
    ListNode() {}
    // 带一个参数的构造函数,用于初始化节点的值
    ListNode(int val) { this.val = val; }
    // 带两个参数的构造函数,用于初始化节点的值和指向下一个节点的引用
    ListNode(int val, ListNode next) { this.val = val; this.next = next; }
}


http://www.kler.cn/a/529627.html

相关文章:

  • 本地部署DeepSeek-R1保姆级教程
  • AI学习指南HuggingFace篇-Tokenizers 与文本处理
  • 代理模式 - 代理模式的应用
  • go-zero学习笔记(一)
  • 【后端开发】字节跳动青训营Cloudwego脚手架
  • 代码随想录34 动态规划
  • GMSL 明星产品之 MAX96724
  • CNN的各种知识点(四): 非极大值抑制(Non-Maximum Suppression, NMS)
  • DeepSeek为什么超越了OpenAI?从“存在主义之问”看AI的觉醒
  • 【Elasticsearch】_all 查询
  • Arduino大师练成手册 -- 控制 AS608 指纹识别模块
  • 低空经济专业课程详解
  • 用deepseek解决python问题——在cmd终端运行python指令弹出应用商店,检查路径已经加入环境变量
  • spacemacs gnuplot
  • 双向链表的快速排序函数
  • 猴子吃桃问题
  • DeepSeek V3 vs R1:大模型技术路径的“瑞士军刀“与“手术刀“进化
  • BUUCTF_[安洵杯 2019]easy_web(preg_match绕过/MD5强碰撞绕过/代码审计)
  • 一文了解DeepSeek
  • Linux学习之DNS基础服务器搭建
  • Java死锁问题
  • OpenAI深夜反击:o3-mini免费上线,能否撼动DeepSeek的地位?
  • 青少年编程与数学 02-008 Pyhon语言编程基础 14课题、创建函数
  • C++ Primer 标准库类型string
  • C#面试常考随笔10:C#中有哪些常用的容器类,各有什么特点?
  • 如何使用SliverGrid组件