总第64篇/程序员小吴

LeetCode上第 445 号问题:Add Two Numbers II

题目描述

给定两个非空链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储单个数字。将这两数相加会返回一个新的链表。

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

进阶:

如果输入链表不能修改该如何处理?换句话说,你不能对列表中的节点进行翻转。

示例:

输入: (7 -> 2 -> 4 -> 3) + (5 -> 6 -> 4)     
输出: 7 -> 8 -> 0 -> 7

思路解析

由于计算时要保证最右边的数对齐,那么很自然的想到先用 栈 存放链表中的每个值,然后依次计算。由于相加时可能产生进位,所以使用一个 flag 表示是否有进位。

提示:若栈中元素相加结束之后仍有进位,则需要新加入一个头结点。

动画演示

动画演示 Made by 王琛

参考代码

 1class Solution:
2    def addTwoNumbers(self, l1, l2):
3        # 分别入栈
4        stack1 = []
5        stack2 = []
6        while l1:
7            stack1.append(l1.val)
8            l1 = l1.next
9        while l2:
10            stack2.append(l2.val)
11            l2 = l2.next
12
13        flag = 0
14        head = None
15        while stack1 or stack2 or flag != 0:
16            if stack1:
17                flag += stack1.pop()
18            if stack2:
19                flag += stack2.pop()
20            node = ListNode(flag % 10)
21            node.next = head
22            head = node
23            flag = flag // 10
24        return head

代码截图


©著作权归作者所有:来自51CTO博客作者mb5fe18fab305a5的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. C语言的一些练习以及写一个猜数字游戏
  2. 动画:面试算法之求二叉树的下一节点
  3. php用逗号格式化数字的方法(代码示例)
  4. PHP重置数组为连续数字索引的三种方式
  5. 分享一个匹配8-16位数字和字母密码的正则表达式
  6. php+nodeJs+thrift协议,实现zookeeper节点数据自动发现
  7. php如何删除字符串中的重复数字或字符
  8. PHP随机生成不重复的8位卡号(数字)和卡密(字符串)
  9. php实现字母数字混合验证码

随机推荐

  1. Android Studio Error:Could not find co
  2. ANDROID学习之路
  3. Android(安卓)如何退出程序
  4. android textview系统默认的颜色值是多少
  5. android 调用打电话URI
  6. android perimission 和 user-perimissio
  7. Android使EditText和SearchView取消默认
  8. 新建项目出现android support library问
  9. 利用View.inflate加载xml
  10. Android WebRTC