大家好,我是编程熊,今天是LeetCode每日一题的第二天,一起学习的是LeetCode第二题《两数相加》。

题意

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

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

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

示例

输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.

题解

因为链表是逆序的,所以两个链表可以从头开始逐位相加,但两个链表可能不一样长,对于短的链表可以高位补 0

需要注意的是,遍历完两个链表后,最高位需要进位而额外增加一位。

时间复杂度: O(n)n 为两个链表中较长的长度。

空间复杂度: O(1)

知识点总结: 链表

C++代码

class Solution {
public:
ListNode *addTwoNumbers(ListNode *l1, ListNode *l2) {
ListNode* head = new ListNode();
ListNode* currentPos = head;
int v = 0;
while(l1 || l2 || v) {
int v1 = l1 ? l1->val : 0, v2 = l2 ? l2->val : 0;
int res = (v + v1 + v2) / 10;
v = (v1 + v2 + v) % 10;
currentPos->val = v;
v = res;
if (l1) l1 = l1->next;
if (l2) l2 = l2->next;
if (l1 || l2 || v) {
currentPos->next = new ListNode();
currentPos = currentPos->next;
}
}
return head;
}
};

Java代码

class Solution {
public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
ListNode head = new ListNode();
ListNode currentPos = head;
int v = 0;
while (l1 != null || l2 != null || v != 0) {
int v1 = l1 != null ? l1.val : 0;
int v2 = l2 != null ? l2.val : 0;
int res = (v + v1 + v2) / 10;
v = (v + v1 + v2) % 10;
currentPos.val = v;
v = res;
if (l1 != null) l1 = l1.next;
if (l2 != null) l2 = l2.next;
if (l1 != null || l2 != null || v != 0) {
currentPos.next = new ListNode();
currentPos = currentPos.next;
}
}
return head;
}
}

题目链接: https://leetcode-cn.com/problems/add-two-numbers/

我是编程熊,致力于让大家都成为更好的人,欢迎 『关注』、『点赞』、『转发』支持~

最新文章

  1. CSS3 莲花盛开动画
  2. Elasticsearch增删改查 之 —— Update更新
  3. redis数据类型
  4. 不得不玩玩NHibernate
  5. mysql 表被锁处理方案
  6. zabbix 安装
  7. 第 13 章 剖析el表达式
  8. jmeter 使用URL重写处理用户会话
  9. ExtJs之Ext.form.field.ComboBox组合框
  10. ASCII码常用值
  11. android夸项目调用
  12. AngularJS: 自定义指令与控制器数据交互
  13. poj 2411 Mondriaan's Dream(状态压缩dp)
  14. org.eclipse.birt.report.data.oda.jdbc.JDBCException: Missing properties in Connection.open(Propertie
  15. hdu Oulipo(kmp)
  16. Python 导入模块
  17. C++中指向类的指针
  18. centos7.2 Apache+PHP7.2+Mysql5.6环境搭建
  19. .Net Core 在 Linux-Centos上的部署实战教程(三)
  20. LVS + Keepalived 理论

热门文章

  1. [并发编程 - 多线程:信号量、死锁与递归锁、时间Event、定时器Timer、线程队列、GIL锁]
  2. Spring Cloud Alibaba Nacos Discovery 实战
  3. 用JIRA管理你的项目——(三)基于LDAP用户管理
  4. Linux下script命令录制、回放和共享终端操作script -t 2> timing.log -a output.session # 开始录制
  5. 保姆级别的RabbitMQ教程!一看就懂!(有安装教程,送安装需要的依赖包,送Java、Golang两种客户端教学Case)
  6. 【转载】基于Linux命令行KVM虚拟机的安装配置与基本使用
  7. make: g77: Command not found 修改Makefile.in中的编译文件中的g77为gfortran
  8. mysql 无法执行select查询
  9. 6.2 gzip:压缩或解压文件
  10. STM32自己的封装库