目录

1290 二进制链表转整数

1290. 二进制链表转整数

给你一个单链表的引用结点 head。链表中每个结点的值不是 0 就是 1。已知此链表是一个整数数字的二进制表示形式。

请你返回该链表所表示数字的 十进制值 。

示例 1:

https://assets.leetcode-cn.com/aliyun-lc-upload/uploads/2019/12/15/graph-1.png

1
2
3
输入:head = [1,0,1]
输出:5
解释:二进制数 (101) 转化为十进制数 (5)

示例 2:

1
2
输入:head = [0]
输出:0

示例 3:

1
2
输入:head = [1]
输出:1

示例 4:

1
2
输入:head = [1,0,0,1,0,0,1,1,1,0,0,0,0,0,0]
输出:18880

示例 5:

1
2
输入:head = [0,0]
输出:0

提示:

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