首页 > 其他 > 详细

[Algorithm] 1290. Convert Binary Number in a Linked List to Integer

时间:2019-12-21 10:07:49      阅读:98      评论:0      收藏:0      [点我收藏+]

Given head which is a reference node to a singly-linked list. The value of each node in the linked list is either 0 or 1. The linked list holds the binary representation of a number.

Return the decimal value of the number in the linked list.

 

Example 1:

技术分享图片

Input: head = [1,0,1]
Output: 5
Explanation: (101) in base 2 = (5) in base 10

Example 2:

Input: head = [0]
Output: 0

Example 3:

Input: head = [1]
Output: 1

Example 4:

Input: head = [1,0,0,1,0,0,1,1,1,0,0,0,0,0,0]
Output: 18880

Example 5:

Input: head = [0,0]
Output: 0

 

/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */
/**
 * @param {ListNode} head
 * @return {number}
 */
var getDecimalValue = function(head) {
   let res = 0;  

    // Traverse linked list  
    while (head != null) {  
        // shift bit to accomodate value and add head‘s data  
        res = (res << 1) | head.val;  

        // Move next  
        head = head.next;  
    }  
    return res; 
};

 

[Algorithm] 1290. Convert Binary Number in a Linked List to Integer

原文:https://www.cnblogs.com/Answer1215/p/12075723.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!