二進位操作: bit逆序翻轉 Reverse Bits_Leetcode_#190

閱讀時間約 3 分鐘

題目敘述: Reverse Bits

給定一個32bit的整數,請逆序翻轉其二進位表達式,輸出翻轉過後的數字。

例如輸入是二進位1010111 逆序翻轉後是 1110101,對應的十進位數值是117


測試範例

Example 1:

Input: n = 00000010100101000001111010011100
Output: 964176192 (00111001011110000010100101000000)

Explanation: The input binary string 00000010100101000001111010011100 represents the unsigned integer 43261596, so return 964176192 which its binary representation is 00111001011110000010100101000000.

Example 2:

Input: n = 11111111111111111111111111111101
Output: 3221225471 (10111111111111111111111111111111)

Explanation: The input binary string 11111111111111111111111111111101 represents the unsigned integer 4294967293, so return 3221225471 which its binary representation is 10111111111111111111111111111111.

約束條件

Constraints:

  • The input must be a binary string of length 32

 輸入保證在32bit整數範圍內


演算法 二進位操作

逆序翻轉bit相當於從LSB低位元到MSB高位元把每個bit讀取出來,
接著反方向從MSB到LSB擺好
最後整個binary bits representation就相當於逆序翻轉的二進位數字。

原本的數字                 逆序的數字​
高位元MSB ...低位元LSB <-> 低位元LSB ... 高位元MSB

例如輸入是二進位1010111 逆序翻轉後是 1110101,對應的十進位數值是117

詳細過程

1010111

讀取到1 -> 逆序輸出1


1010111

讀取到1 -> 逆序輸出11


1010111

讀取到1 -> 逆序輸出111


1010111

讀取到0 -> 逆序輸出1110


1010111

讀取到1 -> 逆序輸出11101


1010111

讀取到0 -> 逆序輸出111010


1010111

讀取到0 -> 逆序輸出1110101

最後,對應的十進位數值是117


程式碼 二進位操作

class Solution:
def reverseBits(self, n: int) -> int:

rev_bits = 0
for i in range( 32 ):

rev_bits = rev_bits << 1

# rev_bits get binary bit from LSB to MSB of n
rev_bits = rev_bits | ( n & 1 )

n = n >> 1

return rev_bits

複雜度分析

時間複雜度: O(1)

for loop長度固定為O(32) = O(1)


空間複雜度O(1)

只有用到固定尺寸的臨時變數,所需空間為O(1)


Reference:

[1] Reverse Bits - LeetCode

avatar-img
90會員
425內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
題目敘述 Count Number of Teams 給定一個輸入陣列rating,裡面代表每位成員的評分 挑選三位成員,對應到三個index i, j, k 且 i < j < k 如果rating[i] < rating[j] < rating[k] ,則此三人可以組成一隊。 或者ra
題目敘述: Minimum Cost to Convert String I 給定字元轉換映射表original, changes和對硬的成本陣列cost。 請問字串source轉換到字串destination的最小成本是多少? 如果無解,請返回-1 如果有解,請返回整體的轉換最小成本。
題目敘述 Sort the Jumbled Numbers 給定兩個輸入陣列 第一個是映射表,提供0~9 mapping到新數字的映射關係。 第二個陣列是原始數值。 請重新排序原始數值,排序依據是根據映射表對應之後的新數值的大小決定。 如果對應之後的新數值大小相同,則由原本的前後相對順序決定。
題目敘述 Sort Array by Increasing Frequency Leetcode #1636 給定一個輸入陣列,請依照出現頻率的多寡從低頻到高頻排列陣列元素。 如果有兩個元素的出現頻率相同,依照元素大小從大到小排列。 測試範例 Example 1: Input: nums
給定兩個輸入陣列,第一個陣列代表每個人的姓名,第二個陣列代表每個人的身高。依照身高從高到矮進行排列,輸出每個人的名字。本文介紹了一個根據身高排列人名的算法,並提供了相關的程式碼和時間複雜度分析。
給定一個輸入陣列,每一個tuple代表節點之間了從屬關係。 請從從屬關係重建整顆二元樹,並且返回整顆二元樹的根結點。
題目敘述 Count Number of Teams 給定一個輸入陣列rating,裡面代表每位成員的評分 挑選三位成員,對應到三個index i, j, k 且 i < j < k 如果rating[i] < rating[j] < rating[k] ,則此三人可以組成一隊。 或者ra
題目敘述: Minimum Cost to Convert String I 給定字元轉換映射表original, changes和對硬的成本陣列cost。 請問字串source轉換到字串destination的最小成本是多少? 如果無解,請返回-1 如果有解,請返回整體的轉換最小成本。
題目敘述 Sort the Jumbled Numbers 給定兩個輸入陣列 第一個是映射表,提供0~9 mapping到新數字的映射關係。 第二個陣列是原始數值。 請重新排序原始數值,排序依據是根據映射表對應之後的新數值的大小決定。 如果對應之後的新數值大小相同,則由原本的前後相對順序決定。
題目敘述 Sort Array by Increasing Frequency Leetcode #1636 給定一個輸入陣列,請依照出現頻率的多寡從低頻到高頻排列陣列元素。 如果有兩個元素的出現頻率相同,依照元素大小從大到小排列。 測試範例 Example 1: Input: nums
給定兩個輸入陣列,第一個陣列代表每個人的姓名,第二個陣列代表每個人的身高。依照身高從高到矮進行排列,輸出每個人的名字。本文介紹了一個根據身高排列人名的算法,並提供了相關的程式碼和時間複雜度分析。
給定一個輸入陣列,每一個tuple代表節點之間了從屬關係。 請從從屬關係重建整顆二元樹,並且返回整顆二元樹的根結點。
你可能也想看
Google News 追蹤