日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

LeetCode—1290.二进制链表转整数(Java)

發(fā)布時間:2025/3/21 java 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode—1290.二进制链表转整数(Java) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

文章目錄

    • 1.題目:
    • 2.代碼實例
    • 3.代碼分析

1.題目:

給你一個單鏈表的引用結(jié)點(diǎn) head。鏈表中每個結(jié)點(diǎn)的值不是 0 就是 1。已知此鏈表是一個整數(shù)數(shù)字的二進(jìn)制表示形式。

請你返回該鏈表所表示數(shù)字的 十進(jìn)制值 。
示例 1:


輸入:head = [1,0,1]
輸出:5
解釋:二進(jìn)制數(shù) (101) 轉(zhuǎn)化為十進(jìn)制數(shù) (5)
示例 2:

輸入:head = [0]
輸出:0
示例 3:

輸入:head = [1]
輸出:1
示例 4:

輸入:head = [1,0,0,1,0,0,1,1,1,0,0,0,0,0,0]
輸出:18880
示例 5:

輸入:head = [0,0]
輸出:0

提示:

鏈表不為空。
鏈表的結(jié)點(diǎn)總數(shù)不超過 30。
每個結(jié)點(diǎn)的值不是 0 就是 1。

2.代碼實例

class Solution {public int getDecimalValue(ListNode head) {ListNode cur = head;int ans = 0;while (cur != null) {ans <<= 1;ans += cur.val;cur = cur.next;}return ans;} }

3.代碼分析

在做分析之前我們要先了解一下什么叫做位運(yùn)算,以及位運(yùn)算的使用方法

a shl b就表示把a(bǔ)轉(zhuǎn)為二進(jìn)制后左移b位(在后面添b個0)。例如100的二進(jìn)制為1100100,而110010000轉(zhuǎn)成十進(jìn)制是400,那么100 shl 2 = 400。可以看出,a shl b的值實際上就是a乘以2的b次方,因為在二進(jìn)制數(shù)后添一個0就相當(dāng)于該數(shù)乘以2。

那么我們這道題已經(jīng)是二進(jìn)制的形式了,就可以直接使用了

下面我們以101來作為例子分析
第一輪:
ans=0
ans<<=1之后的結(jié)果為ans=0(1*2的0次冪)
我們?nèi)〕鰜淼墓?jié)點(diǎn)是1
ans += cur.val之后的結(jié)果為ans=0+1=1
cur = cur.next之后的結(jié)果為0

二進(jìn)制變化的演示:

ans一開始是0
左移1之后變?yōu)?00
加上cur.val之后變?yōu)?00+1=01

第二輪:
ans=1
ans<<=1之后的結(jié)果為ans=2(1*2的1次冪)
我們?nèi)〕鰜淼墓?jié)點(diǎn)是0
ans += cur.val之后的結(jié)果為ans=2+0=2
cur = cur.next之后的結(jié)果為1

二進(jìn)制變化的演示:

ans為:01
左移之后變?yōu)?010
加上cur.val之后變?yōu)?010+0=010

第三輪:
ans=2
ans<<=1之后的結(jié)果為ans=4(2*2的1次冪)
我們?nèi)〕鰜淼墓?jié)點(diǎn)是1
ans += cur.val之后的結(jié)果為ans=4+1=2
cur = cur.next之后的結(jié)果為null

二進(jìn)制變化的演示:

ans為:010
左移之后變?yōu)?0100
加上cur.val之后變?yōu)?0100+1=0101

《新程序員》:云原生和全面數(shù)字化實踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結(jié)

以上是生活随笔為你收集整理的LeetCode—1290.二进制链表转整数(Java)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。