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.两数相加(中等)
题目描述: 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来 ...
随机推荐
- Docker镜像的备份和恢复
备份: docker save -o [tar包真实路径] [镜像名 ] 如:docker save -o /usr/docker_data/mongo-backup.tar mongo 导出: ...
- 训练1-A
一块花布条,里面有些图案,另有一块直接可用的小饰条,里面也有一些图案.对于给定的花布条和小饰条,计算一下能从花布条中尽可能剪出几块小饰条来呢? Input 输入中含有一些数据,分别是成对出现的花布条和 ...
- 不引用第三方变量交换a和b的值
方法一:(可操作字符) a = a^b; b = a^b; a = a^b; 方法二:(可操作字符) a=a+b; b=a-b; a=a-b; 方法三:(不可以操作字符) a=a*b; b=a/b; ...
- Supervisor 从入门到放弃
前言 Supervisor是一个客户端/服务器系统,允许其用户在类UNIX操作系统上控制许多进程.(官方解释) 简单点来讲,就是一个监控脚本运行的工具,不过他可以统一化管理,laravel的队列文档上 ...
- Java工具类使用注意事项
(以下摘自阿里巴巴Java开发手册) 1. [强制]获取单例对象需要保证线程安全,其中的方法也要保证线程安全. 说明:资源驱动类.工具类.单例工厂类都需要注意. 5. [强制]SimpleDateFo ...
- 轻量级Java EE开发框架设计系统应用架构
首先来说一下Java EE 概述 其中常说的三大框架即是:ssh Spring:功能强大的组件粘合济,能够将你的所有的java功能模块用配置文件的方式组合起来(还让你感觉不到spring的存在)成为一 ...
- php中的form表单
表单处理 表单的概念在生活中很常见,就像是问卷调查表一样,别人先把问卷发给你,你照着问卷的要求填写,完事过后再将填完的问卷发给别人,从而达到一个将别人需要的信息传递给别人的一种方式. 传统的网页大多数 ...
- CF409C Magnum Opus
CF409C Magnum Opus 题意翻译 题目背景 愚人节题目,题面似乎是一位名叫Nicolas Flamel的炼金术士用拉丁文写的某种物质的配方,结合谷歌尝试翻译了一下: 吾友: 哲人石所言不 ...
- Hadoop高速入门
Hadoop高速入门 先决条件 支持平台 GNU/Linux是产品开发和执行的平台. Hadoop已在有2000个节点的GNU/Linux主机组成的集群系统上得到验证. Win32平台是作为开发平台支 ...
- SOA概念具体解释
1.概述 1.1基本定义 SOA(Service-Oriented Architecture)既面向服务的体系结构,是一个组件模型.它将应用程序猿的不同功能可是(称为服务)通过定义良好的接口联系起来. ...