leetcode — add-two-numbers
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
/**
* Source : https://oj.leetcode.com/problems/add-two-numbers/
*
* Created by lverpeng on 2017/6/23.
*
* You are given two linked lists representing two non-negative numbers.
* The digits are stored in reverse order and each of their nodes contain a single digit.
* Add the two numbers and return it as a linked list.
*
* Input: (2 -> 4 -> 3) + (5 -> 6 -> 4)
* Output: 7 -> 0 -> 8
*
*/
public class AddTwoNumbers {
/**
* 问题就是求两个数的和,只不过这两个数分别存在两个链表中,低位在前,高位在后,求出的和也存在链表中
* 循环较长的那个链表:
* 如果是当前有个链表都有值,则将两个数与上次计算的商(也就是进位)求和,结果的对于10的余数存于结果链表对一个的位置,结果对于10的商保存在变量中(也就是进位),
* 如果已经超过了其中一个链表的长度,则直接把另一个链表的数存入结果链表
*
* @param num1
* @param num2
* @return
*/
public List<Integer> addTwoNumbers (List<Integer> num1, List<Integer> num2) {
List<Integer> numbers = new ArrayList<Integer>();
int size = 0;
if (num1.size() > num2.size()) {
size = num1.size();
} else {
size = num2.size();
}
int carry = 0;
int sum = 0;
for (int i = 0; i < size; i++) {
if (num1.size() > i && num2.size() > i) {
sum = carry + num1.get(i) + num2.get(i);
} else if (num1.size() - 1 > i) {
sum = carry + num1.get(i);
} else {
sum = carry + num2.get(i);
}
numbers.add(sum % 10);
carry = sum / 10;
}
if (carry > 0) {
numbers.add(carry);
}
return numbers;
}
public List<Integer> addTwoNumbersRefactor (List<Integer> num1, List<Integer> num2) {
List<Integer> result = new ArrayList<Integer>();
int size = num1.size() > num2.size() ? num1.size() : num2.size();
int carry = 0;
int sum = 0;
for (int i = 0; i < size; i++) {
sum = carry + getNumber(num1, i) + getNumber(num2, i);
carry = sum / 10;
result.add(sum % 10);
}
if (carry > 0) {
result.add(carry);
}
return result;
}
private int getNumber(List<Integer> numbers, int i) {
if (i < 0 || i >= numbers.size()) {
return 0;
}
return numbers.get(i);
}
public static void main(String[] args) {
AddTwoNumbers addTwoNumbers = new AddTwoNumbers();
List<Integer> num1 = new ArrayList<Integer>(){{
add(2);
add(4);
add(3);
}};
List<Integer> num2 = new ArrayList<Integer>(){{
add(5);
add(6);
add(4);
}};
System.out.println(addTwoNumbers.addTwoNumbers(num1, num2));
System.out.println(addTwoNumbers.addTwoNumbersRefactor(num1, num2));
}
}
leetcode — add-two-numbers的更多相关文章
- [LeetCode] Add Two Numbers II 两个数字相加之二
You are given two linked lists representing two non-negative numbers. The most significant digit com ...
- [LeetCode] Add Two Numbers 两个数字相加
You are given two linked lists representing two non-negative numbers. The digits are stored in rever ...
- LeetCode Add Two Numbers II
原题链接在这里:https://leetcode.com/problems/add-two-numbers-ii/ 题目: You are given two linked lists represe ...
- LeetCode: Add Two Numbers 解题报告
Add Two NumbersYou are given two linked lists representing two non-negative numbers. The digits are ...
- Leetcode:Add Two Numbers分析和实现
Add Two Numbers这个问题的意思是,提供两条链表,每条链表表示一个十进制整数,其每一位对应链表的一个结点.比如345表示为链表5->4->3.而我们需要做的就是将两条链表代表的 ...
- [LeetCode] Add Two Numbers题解
Add Two Numbers: You are given two non-empty linked lists representing two non-negative integers. Th ...
- [Leetcode] Add two numbers 两数之和
You are given two linked lists representing two non-negative numbers. The digits are stored in rever ...
- [LeetCode] Add Two Numbers
You are given two linked lists representing two non-negative numbers. The digits are stored in rever ...
- LeetCode——Add Two Numbers
Question:You are given two linked lists representing two non-negative numbers. The digits are stored ...
- [LeetCode] Add Two Numbers 链表
You are given two linked lists representing two non-negative numbers. The digits are stored in rever ...
随机推荐
- Base64加密转换原理与代码实现
一.Base64实现转换原理 它是用64个可打印字符表示二进制所有数据方法.由于2的6次方等于64,所以可以用每6个位元(bit)为一个单元,对应某个可打印字符.我们知道三个字节(byte)有24个位 ...
- Django跨域(前端跨域)
前情回顾 在说今天的问题之前先来回顾一下有关Ajax的相关内容 Ajax的优缺点 AJAX使用Javascript技术向服务器发送异步请求: AJAX无须刷新整个页面: 因为服务器响应内容不再是整个页 ...
- 杨其菊201771010134《面向对象程序设计(Java)》第三周学习总结
<面向对象程序设计(Java)>第三周学习总结 第一部分:理论知识 这周课程没有新进度,由于感觉对基础语法的不熟悉,复习了一遍前三章的细碎知识,学到一些之前不知道的原理: 1.计算机高级语 ...
- CSS3美化网页!!
一.span标签:能让某几个文字或者某个词语凸显出来 <p> 今天是11月份的<span>第一天</span>,地铁卡不打折了 ...
- ActiveMQ_1学习
学习资源 官方文档 http://activemq.apache.org/features.html 下载ActiveMQ选择版本 http://activemq.apache.org/overvie ...
- w9 Ansible批量管理与维护
Ansible是2013年推出的一种通用自动化工具,可用于配置管理或工作流程自动化.配置管理是一种“基础架构代码”实践,它将事物编码,例如应该在系统上安装什么包和版本,或者应该运行什么守护进程.工作流 ...
- 安装php7.2并且整合nginx且分开部署
1.安装php 7.2 2.php配置 3.nginx配置 4.测试 5.报错与解决 6.利用upstream实现负载均衡 1.安装php 7.2 启动容器: liwangdeMacBook-Air: ...
- Codeforces Round #539--1113B - Sasha and Magnetic Machines
https://codeforces.com/contest/1113/problem/B 思想不难,但是在比较大小的时候,我选择了很笨的方法,我用两个数变化之后的差值大小来进行选择,然后最后再进行数 ...
- array_filter()函数
用回调函数过滤数组中的值 array_filter(array,callbackfunction); 返回过滤后的数组
- oracle-查询-时间条件查询
select * from 表名 where date =to_date('时间','yyyy-dd-mm');