Java实现 LeetCode 445 两数相加 II
2024-10-09 04:26:19
445. 两数相加 II
给定两个非空链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储单个数字。将这两数相加会返回一个新的链表。
你可以假设除了数字 0 之外,这两个数字都不会以零开头。
进阶:
如果输入链表不能修改该如何处理?换句话说,你不能对列表中的节点进行翻转。
示例:
输入: (7 -> 2 -> 4 -> 3) + (5 -> 6 -> 4)
输出: 7 -> 8 -> 0 -> 7
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
//栈
LinkedList<Integer> s1 = new LinkedList<>();
LinkedList<Integer> s2 = new LinkedList<>();
while(l1 != null) {
s1.addFirst(l1.val);
l1 = l1.next;
}
while(l2 != null) {
s2.addFirst(l2.val);
l2 = l2.next;
}
int carry = 0;
ListNode lastNode = null;
while(!s1.isEmpty() || !s2.isEmpty()) {
int a1 = 0, a2 = 0;
if(!s1.isEmpty()) {
a1 = s1.removeFirst();
}
if(!s2.isEmpty()) {
a2 = s2.removeFirst();
}
ListNode curNode = new ListNode((a1 + a2 + carry) % 10);
carry = (a1 + a2 + carry) / 10;
curNode.next = lastNode;
lastNode = curNode;
}
if(carry > 0) {
ListNode curNode = new ListNode(carry);
curNode.next = lastNode;
lastNode = curNode;
}
return lastNode;
}
}
最新文章
- Android基于mAppWidget实现手绘地图(十四)–在一个应用中使用多个地图
- WebStorm9
- DB2物化表
- linux下mysql的root密码忘记解决方
- bjfu1208 中位数
- Be Sociable, Share!
- NOI2015 小园丁与老司机
- Cocos2d-X中实现菜单特效
- 解决Eclipse下第三方库无法导航源代码
- python 识别图片上的数字
- 整合多个网络的拓扑结构并降维(Mashup)
- 学习git踩坑之路
- OpenCV——图像的深度与通道数讲解
- java 异常链
- annovar积累
- 算法笔记_145:拓扑排序的应用(Java)
- 【Java实战】DecimalFormat对数值格式化的舍入问题——RoundingMode
- Ubuntu系统下安装并配置hive-2.1.0
- 限制printk打印频率函数printk_ratelimit【转】
- C++ 学习使用