给你一个单链表的引用结点 head。链表中每个结点的值不是 0 就是 1。已知此链表是一个整数数字的二进制表示形式。
请你返回该链表所表示数字的 十进制值 。
示例 1:
1
2
3
|
输入:head = [1,0,1]
输出:5
解释:二进制数 (101) 转化为十进制数 (5)
|
示例 2:
示例 3:
示例 4:
1
2
|
输入:head = [1,0,0,1,0,0,1,1,1,0,0,0,0,0,0]
输出:18880
|
示例 5:
提示:
1
2
3
|
链表不为空。
链表的结点总数不超过 30。
每个结点的值不是 0 就是 1。
|
思路
1
2
|
如果一个十进制的数字,999要和1拼接,需要999*10+1 = 999∗10+1=9991
如果一个二进制的数字,110要和1拼接,需要110*2+1 = 110∗2+1=1101 (注意按照二进制的方法计算)
|
代码
1
2
3
4
5
6
7
8
9
10
11
|
class Solution(object):
def getDecimalValue(self, head):
"""
:type head: ListNode
:rtype: int
"""
result = 0
while head:
result = head.val + (result << 1)
head = head.next
return result
|