LeetCode Golang 2. 两数相加
2. 两数相加
给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。
如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
您可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例:
输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807
错误解法:
错误思路: 将数字读出来还原, 进行加法得到sum, 再拆分sum写入到新的链表中
错误原因: 大数字会导致内存溢出
func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
if l1 == nil || l2 == nil {
return nil
}
l := new(ListNode)
rst := l pow10 := func(a int) int {
if a == 0 {
return 1
}
rst := 1
for i := 1; i <= a; i++ {
rst *= 10
}
return rst
} getInt := func(l *ListNode) (int) {
if l == nil {
return 0
}
nums := []int{}
for l != nil {
nums = append(nums, l.Val)
l = l.Next
}
rst := 0
for k, v := range nums {
rst += pow10(k) * v
}
return rst
} rstNum := getInt(l1) + getInt(l2)
rstArr := strconv.Itoa(rstNum)
bits := len(rstArr)
for i := 1; i <= bits; i++ {
l.Val = rstNum / pow10(i-1) % 10
if i == bits {
break
}
l.Next = new(ListNode)
l = l.Next
}
return rst
}
正确解法:
思路: 直接模拟加法过程
package main import "fmt" type ListNode struct {
Val int
Next *ListNode
} /*
输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807
*/ //[1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1]
//[5,6,4] func main() {
l1 := new(ListNode)
l2 := new(ListNode)
tmp1 := l1
tmp2 := l2
nums1 := []int{3, 5, 2}
nums2 := []int{5,6,4} for i := 0; i < len(nums1); i++ {
tmp1.Val = nums1[i]
if i == len(nums1)-1 {
break
}
tmp1.Next = new(ListNode)
tmp1 = tmp1.Next
}
for i := 0; i < len(nums2); i++ {
tmp2.Val = nums2[i]
if i == len(nums2)-1 {
break
}
tmp2.Next = new(ListNode)
tmp2 = tmp2.Next
} fmt.Println(l2.getInt())
fmt.Println(l1.getInt())
l2 = addTwoNumbers(l1, l2)
fmt.Println(l2.getInt()) } func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
if l1 == nil || l2 == nil {
return nil
} l := new(ListNode)
l.Val = 0
tmp := l
flag := 0 // flag标志位, 模拟加法中的进位加1 for {
num := l1.Val + l2.Val + tmp.Val
if num >= 10 {
tmp.Val = num % 10
flag = 1
} else {
tmp.Val = num
} if l1.Next == nil && l2.Next == nil {
break
}
l1 = l1.Next
l2 = l2.Next
if l1 == nil {
l1 = new(ListNode)
l1.Val = 0
}
if l2 == nil {
l2 = new(ListNode)
l2.Val = 0
} tmp.Next = new(ListNode)
if flag == 1 {
tmp.Next.Val = 1
flag = 0
} else {
tmp.Next.Val = 0
}
tmp = tmp.Next
}
if flag == 1 { // 这个判断一定要加, 因为 5 + 5 返回 0,1
tmp.Next = new(ListNode)
tmp.Next.Val = 1
} return l
} func (l *ListNode) Length() int {
if l == nil {
return 0
}
i := 0
for l != nil {
l = l.Next
i++
}
return i
} // 返回链表中的值
func (l *ListNode) getInt() (int) {
if l == nil {
return 0
}
nums := []int{}
for l != nil {
nums = append(nums, l.Val)
l = l.Next
}
rst := 0
for k, v := range nums {
rst += pow10(k) * v
}
return rst
} // 返回10的几次方 <---- 大数字的情况下在这里首先溢出, 写在这里只为了测试用
func pow10(a int) int {
if a == 0 {
return 1
}
rst := 1
for i := 1; i <= a; i++ {
rst *= 10
}
return rst
}
/* 字体问题: 有些分不清 l 和 1,建议复制到IDE中进行查看 */
LeetCode Golang 2. 两数相加的更多相关文章
- LeetCode :2.两数相加 解题报告及算法优化思路
题目连接:2.两数相加 题意 题目难度标为 中等, 因为题意上有一部分理解难度,以及需要数据结构的链表基础. 还不知道到链表的童鞋可以粗略的看下百度百科或者是翻出数据结构的书看一看,通俗一点的语言来解 ...
- LeetCode | No.2 两数相加
题目描述 给出两个非空的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序的方式存储的,并且它们的每个节点只能存储一位数字.如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和 ...
- LeetCode刷题--两数相加(中等)
题目描述 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来表 ...
- LeetCode练习2 两数相加
问题如下: 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来 ...
- 【LeetCode】2. 两数相加
题目 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来表 ...
- Leetcode:2. 两数相加
题目描述: 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来 ...
- python刷LeetCode:2.两数相加
难度等级:中等 题目描述: 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返 ...
- LeetCode 2:两数相加 Add Two Numbers
给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字.如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和 ...
- leetcode题目2.两数相加(中等)
题目描述: 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来 ...
随机推荐
- VMware 虚拟化技术 创建虚拟机
原文地址:https://www.linuxidc.com/Linux/2017-03/141972.htm 云最成熟的架构是IaaS(Infrastructure as a Service),其中用 ...
- centos7安装nginx(基础篇)
安装所需环境 Nginx 是 C语言 开发,建议在 Linux 上运行,当然,也可以安装 Windows 版本,本篇则使用 CentOS 7 作为安装环境. 一. gcc 安装安装 nginx 需要先 ...
- Python笔记17---------魔法方法
魔法方法也为特殊方法,即用两个下划线形成的(__方法__).自己定义的方法最好不要采用这种方式,因为这些方法会在一些特殊的情况下直接被调用. 1.第一个魔法方法:类中常用的__init__()方法:相 ...
- HDU 5126 stars (四维偏序+树状数组)
题目大意:略 题目传送门 四维偏序板子题 把插入操作和询问操作抽象成$(x,y,z,t)$这样的四元组 询问操作拆分成八个询问容斥 此外$x,y,z$可能很大,需要离散 直接处理四维偏序很困难,考虑降 ...
- [LUOGU]P4098[HEOI2013]ALO
BZOJ上的权限题,流下了贫穷的泪水... 可持久化trie的题. 一开始zz了,看错了题,以为是要把所有的宝石缩起来,后来仔细一看好像只缩一次...昨天刷了一晚上的语文病句题白做了... 这样的话就 ...
- MAVEN的结构认识篇
1.maven的结构认识 src main com imooc calss test com imooc test resources pom.xml 以上是maven项目存在的必须结构!如下图 te ...
- 企业级工作流解决方案(十三)--集成Abp和ng-alain--数据库读写分离
说到程序里面数据库管理,无非就是两件事情,一是数据库操作,对于数据库的操作,各种程序语言都有封装,也就是所谓的ORM框架,.net 方向一般用得比较多和就是.net framework和dapper, ...
- 【codeforces 727D】T-shirts Distribution
[题目链接]:http://codeforces.com/problemset/problem/727/D [题意] 给你6种尺寸的衣服; 他们的尺码依次为S, M, L, XL, XXL, XXXL ...
- Java 学习(9):java Stream & File & IO
Java 流(Stream).文件(File)和IO Java.io 包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io 包中的流支持很多种格式,比如:基本类 ...
- BA-Honeywell R300系统