LEETCODE | PYTHON | 1290 | 二进制链表转整数
1. 题目
给你一个单链表的引用结点 head。链表中每个结点的值不是 0 就是 1。已知此链表是一个整数数字的二进制表示形式。
请你返回该链表所表示数字的 十进制值 。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/convert-binary-number-in-a-linked-list-to-integer
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
2. 代码
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def getDecimalValue(self, head: ListNode) -> int:
#特殊情况判断
if head.next == None:
return head.val
#计算链表长度
cur = head
l = 0
while cur:
l = l + 1
cur = cur.next
#将二进制转为十进制
cur = head
Sum = 0
index = 0 #计数器
while cur:
index = index + 1
num = cur.val
Sum = Sum + num*pow(2,l-index)
#print(num,Sum)
cur = cur.next
return Sum