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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

power of two java_LeetCode算法题-Power Of Two(Java实现)

發布時間:2023/12/2 java 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 power of two java_LeetCode算法题-Power Of Two(Java实现) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這是悅樂書的第194次更新,第200篇原創

01 看題和準備

今天介紹的是LeetCode算法題中Easy級別的第56題(順位題號是231)。給定一個整數,寫一個函數來確定它是否是2的冪。例如:

輸入:1

輸出:true

說明:2^0 = 1

輸入:16

輸出:true

說明:2^4 = 16

輸入:218

輸出:false

本次解題使用的開發工具是eclipse,jdk使用的版本是1.8,環境是win7 64位系統,使用Java語言編寫和測試。

02 第一種解法

此解法是做乘法,新建一個變量,初始值為1,然后循環乘以2,只要該變量小于n,最后判斷該變量和n是否相等。

public boolean isPowerOfTwo(int n) {

long m = 1;

while (m < n) {

m = m*2;

}

return m == n;

}

03 第二種解法

此解法是做除法,先用n對2取余數,如果等于0,說明n是偶數,那么除以2,依次循環判斷。最后判斷是否和1相等。

public boolean isPowerOfTwo2(int n) {

if (n<1) {

return false;

}

while (n%2 == 0) {

n = n/2;

}

return n == 1;

}

04 第三種解法

特殊情況:當n小于1的時候,直接返回false。

正常情況:先將n轉化為二進制字符串,然后判斷此字符串中的1的個數,如果n是2的冪次方,那么1的個數只可能有一個,即此二進制字符串中1的第一次出現的位置和最后一次出現的位置相等。

public boolean isPowerOfTwo3(int n) {

if (n<1) {

return false;

}

String str = Integer.toBinaryString(n);

return str.indexOf("1") == str.lastIndexOf("1");

}

05 第四種解法

特殊情況:當n小于1的時候,直接返回false。

正常情況:借助包裝類Integer,使用其bitCount()方法,統計其二進制數中1的個數,等于1則說明n是2的冪次方,反之則不是。

public boolean isPowerOfTwo4(int n) {

if (n<1) {

return false;

}

return Integer.bitCount(n) == 1;

}

06 第五種解法

特殊情況:當n小于1的時候,直接返回false。

正常情況:與(&)運算的規則是相同的位上均為1時結果為1,如果n是2的2的冪次方,其二進制數是只有一個1的,后面的位都是0,而n-1的二進制數是n的二進制數1變成0,n的二進制數1之后的0變成1,兩者進行與(&)運算,其結果是0。比如:

1的二進制數為1,0的二進制數為0,與運算結果為0

2的二進制數為10,1的二進制數為01,與運算結果為0

4的二進制數為100,3的二進制數為011,與運算結果為0

8的二進制數為1000,7的二進制數為0111,與運算結果為0

public boolean isPowerOfTwo5(int n) {

if (n<1) {

return false;

}

return (n&(n-1)) == 0;

}

07 小結

算法專題目前已連續日更超過一個月,算法題文章56+篇,公眾號對話框回復【數據結構與算法】、【算法】、【數據結構】中的任一關鍵詞,獲取系列文章合集。

以上就是全部內容,如果大家有什么好的解法思路、建議或者其他問題,可以下方留言交流,點贊、留言、轉發就是對我最大的回報和支持!

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的power of two java_LeetCode算法题-Power Of Two(Java实现)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: www.国产区| 日韩私人影院 | 精品国产一区二区三区日日嗨 | 日本一区二区在线视频 | 五月婷婷狠狠 | 影视av | 欧美精品色婷婷五月综合 | 天堂中文在线资 | 黄色一级片免费 | 中文字幕有码在线观看 | 国产精品99久久久久久一二区 | 超碰日日夜夜 | 91成人免费看 | 在线观看免费视频一区二区 | 精品人妻一区二区三区久久夜夜嗨 | 欧美猛交xxx | 成人免费高清在线观看 | 国产青青青 | 日本在线| 国产精品久久久久久影视 | 伊人动漫 | 不卡中文av | 天天干视频在线观看 | 一区二区啪啪啪 | 精品一区二区在线观看视频 | 久久九精品 | 四季av中文字幕一区 | 夜夜精品一区二区无码 | 正在播放欧美 | 欧美变态绿帽cuckold | www.香蕉视频在线观看 | 91午夜影院 | 国产91在线观看 | www.com操| 欧美a∨ | 99精品一级欧美片免费播放 | 精品久久久久久久免费人妻 | 午夜色婷婷 | 色翁荡息又大又硬又粗又爽 | 中文字幕在线天堂 | 99久久久无码国产精品性色戒 | 中文字幕乱码人妻一区二区三区 | 亚洲日本香蕉 | 做爰视频毛片视频 | 色翁荡息又大又硬又粗又爽 | 欧美a级大片| 99蜜桃臀久久久欧美精品网站 | 国产aⅴ激情无码久久久无码 | 97国产精品| 91亚洲视频在线 | 国产精品久久久久久久久毛片 | 国产福利在线看 | 色香欲综合网 | 波多野av在线 | 国产无遮挡又黄又爽 | 久久一二三区 | 一级黄色av片| 国产伦精品一区二区三区视频黑人 | 亚洲免费精品视频 | 亚洲精品高清视频在线观看 | 欧洲一区二区视频 | 免费人妻精品一区二区三区 | 欧美成人免费播放 | 日韩欧美在线观看一区二区 | 爱爱激情网 | 长篇乱肉合集乱500小说日本 | 麻豆va | 欧美日韩在线中文字幕 | 久草视频手机在线观看 | 天天爽天天做 | 中国女人真人一级毛片 | 日日操夜夜操视频 | 日韩免费看 | 宅宅少妇无码 | 大尺度叫床戏做爰视频 | 中文字幕第六页 | 国产精品久久久爽爽爽麻豆色哟哟 | 亚洲第一香蕉网 | 成年人福利 | 私密spa按摩按到高潮 | 欧美成人免费播放 | 制服丝袜av在线 | 久久久久久毛片 | 日韩一级高清 | 毛片福利| 五月婷婷综合激情网 | 乱老熟女一区二区三区 | 性欧美精品 | 国产色在线,com| 久久精品一区二区免费播放 | 天堂а√在线中文在线新版 | 亚洲天堂成人在线观看 | 国产男女视频 | 日韩人妻精品一区二区三区 | av日韩在线免费观看 | 国产精品xx| 免费观看一级黄色片 | 国产精品国产馆在线真实露脸 | 欧美性受xxxx黑人 |