python數(shù)據(jù)結(jié)構(gòu)leetcode338比特位計數(shù)算法
一、題目內(nèi)容
給定一個非負整數(shù) num。對于 0 ≤ i ≤ num 范圍中的每個數(shù)字 i ,計算其二進制數(shù)中的 1 的數(shù)目并將它們作為數(shù)組返回。
示例 1:
輸入: 2
輸出: [0,1,1]
示例 2:
輸入: 5
輸出: [0,1,1,2,1,2]
進階:
給出時間復雜度為O(n*sizeof(integer))的解答非常容易。但你可以在線性時間O(n)內(nèi)用一趟掃描做到嗎?
要求算法的空間復雜度為O(n)。
你能進一步完善解法嗎?要求在C++或任何其他語言中不使用任何內(nèi)置函數(shù)(如 C++ 中的 __builtin_popcount)來執(zhí)行此操作。
二、解題思路
動態(tài)規(guī)劃,i>>1指的是i右移一位,這樣的話i的最低位會被去掉,因此i與i>>1相當于比較最后一位是否為1;
當 i 的最低位為0,則 i 和i >> 1中1的個數(shù)是一樣的,因為0不算進計算1的個數(shù);
否則,最低位為1,1相當于被抹掉了,因此 i >> 1中1的個數(shù)加1就是i 中1的個數(shù);
三、代碼
class Solution:
def countBits(self, num: int) -> list:
dp = [0 for _ in range(num + 1)]
for i in range(num + 1):
i_last_num = i & 1 # 得到i的末位數(shù)字
if i_last_num == 0:
dp[i] = dp[i >> 1]
else:
dp[i] = dp[i >> 1] + i_last_num
return dp
if __name__ == '__main__':
s = Solution()
num = 5
ans = s.countBits(num)
print(ans)以上就是python數(shù)據(jù)結(jié)構(gòu)leetcode338比特位計數(shù)算法的詳細內(nèi)容,更多關于python數(shù)據(jù)結(jié)構(gòu)比特位計數(shù)算法的資料請關注腳本之家其它相關文章!
相關文章
yolov5 win10 CPU與GPU環(huán)境搭建過程
這篇文章主要介紹了yolov5 win10 CPU與GPU環(huán)境搭建過程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
Python中numpy數(shù)組的計算與轉(zhuǎn)置詳解
大家好,本篇文章主要講的是Python中numpy數(shù)組的計算與轉(zhuǎn)置詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12
Python使用PyMySql增刪改查Mysql數(shù)據(jù)庫的實現(xiàn)
PyMysql是Python中用于連接MySQL數(shù)據(jù)庫的一個第三方庫,本文主要介紹了Python使用PyMySql增刪改查Mysql數(shù)據(jù)庫的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-01-01
Python構(gòu)建XML樹結(jié)構(gòu)的方法示例
這篇文章主要介紹了Python構(gòu)建XML樹結(jié)構(gòu)的方法,結(jié)合實例形式分析了Python創(chuàng)建與打印xml數(shù)結(jié)構(gòu)的實現(xiàn)步驟與相關操作技巧,需要的朋友可以參考下2017-06-06
python使用pika庫調(diào)用rabbitmq交換機模式詳解
這篇文章主要介紹了python使用pika庫調(diào)用rabbitmq交換機模式詳解,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-08-08
python pandas利用fillna方法實現(xiàn)部分自動填充功能
這篇文章主要介紹了python pandas通過fillna方法實現(xiàn)部分自動填充功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03

