java练习(5)

server/2025/2/4 9:10:28/

ps:题目来自力扣

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

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

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

class Solution {// 该方法用于将两个逆序存储数字的链表相加,并返回表示和的链表public ListNode addTwoNumbers(ListNode l1, ListNode l2) {// 初始化结果链表的头节点和尾节点,初始值都为 nullListNode head = null, tail = null;// 用于记录进位,初始值为 0int carry = 0;// 只要 l1 或者 l2 还有节点,就继续进行相加操作while (l1 != null || l2 != null) {// 如果 l1 不为空,取其节点值,否则为 0int n1 = l1 != null ? l1.val : 0;// 如果 l2 不为空,取其节点值,否则为 0int 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.ppmy.cn/server/164846.html

相关文章

Scratch 《像素战场》系列综合游戏:像素战场游戏Ⅰ~Ⅲ 介绍

资源下载 Scratch《像素战场》系列综合游戏合集:像素战场游戏Ⅰ~Ⅲ压缩包 https://download.csdn.net/download/leyang0910/90332765 游戏操作介绍 Scratch 《像素战场Ⅰ》操作规则: 这是一款与朋友一起玩的 1v1 游戏。先赢得6轮胜利! WA…

Nginx知识

nginx 精简的配置文件 worker_processes 1; # 可以理解为一个内核一个worker # 开多了可能性能不好events {worker_connections 1024; } # 一个 worker 可以创建的连接数 # 1024 代表默认一般不用改http {include mime.types;# 代表引入的配置文件# mime.types 在 ngi…

Redis真的是单线程的吗?

在学习redis的过程中老是听到:Redis快的原因之一是单线程模型,省去线程切换和竞争的性能开销,但是深入了解redis之后发现它并不是纯的单线程。 Redis 单线程指的是「接收客户端请求->解析请求 ->进行数据读写等操作->发送数据给客户…

【编译系列】Torch.compile()训练编译——算子融合逻辑 工程化

1. 背景: torch.compile()中,Dynamo作为前端负责计算图的捕获,后端有inductor、tvm等进行编译优化。 Dynamo:在Python字节码层面注入pass,实现bytecode-to-bytecode的优化,通过对bytecode逐行进行解析构建FX GraphInductor:负责对FX Graph进行AOTAutograd生成joint-gra…

论文阅读(七):贝叶斯因果表型网络解释遗传变异和生物学知识

1.论文链接:Bayesian Causal Phenotype Network Incorporating Genetic Variation and Biological Knowledge 摘要: 在分离群体中,数量性状基因座(QTL)定位可以确定对表型有因果效应的QTL。这些方法的一个共同特点是Q…

排序算法3

4、希尔排序 希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。希尔排序是基于插入排序的以下两点性质而提出改进方法的:插入排序在对几乎已经排好序的数据操作时,效率高&#xff…

STM32 LED呼吸灯

接线图: 这里将正极接到PA0引脚上,负极接到GND,这样就高电平点亮LED,低电平熄灭。 占空比越大,LED越亮,占空比越小,LED越暗 PWM初始化配置 输出比较函数介绍: 用这四个函数配置输…

LabVIEW无人机航线控制系统

介绍了一种无人机航线控制系统,该系统利用LabVIEW软件与MPU6050九轴传感器相结合,实现无人机飞行高度、速度、俯仰角和滚动角的实时监控。系统通过虚拟仪器技术,有效实现了数据的采集、处理及回放,极大提高了无人机航线的控制精度…