LeetCode 第 461 題“漢明距離”是一道經典的位運算問題,旨在計算兩個整數在二進制表示下不同位的個數。題目要求簡單直接:給定兩個整數 x 和 y,計算并返回它們之間的漢明距離。
漢明距離的定義為兩個等長字符串對應位置不同字符的個數。在本題中,我們將其應用于整數的二進制表示。例如,對于 x = 1(二進制 0001)和 y = 4(二進制 0100),它們在第一和第三位不同,因此漢明距離為 2。
以下是幾種常見的解法,從暴力到優化,逐步深入。
最直觀的方法是逐位比較 x 和 y 的二進制位。我們可以通過循環 32 次(假設為 32 位整數),每次檢查最低位是否相同,然后右移一位。
步驟:
x & 1 和 y & 1 獲取)。x >>= 1, y >>= 1)。時間復雜度:O(1),因為固定循環 32 次。
空間復雜度:O(1)。
利用位運算中的異或(XOR)操作,可以更高效地解決問題。異或運算的規則是:相同為 0,不同為 1。因此,將 x 和 y 進行異或后,結果中 1 的個數即為漢明距離。
步驟:
z = x ^ y。z & (z - 1) 不斷清除最低位的 1,直到 z 變為 0。每次操作計數器加 1。時間復雜度:O(1),因為整數位數固定。
空間復雜度:O(1)。
許多編程語言提供了內置函數來統計二進制中 1 的個數(例如 Java 的 Integer.bitCount() 或 Python 的 bin().count('1'))。這種方法代碼簡潔,但底層實現通常基于高效算法。
以下是方法二的 Python 實現,使用 Brian Kernighan 算法:
def hammingDistance(x: int, y: int) -> int:
z = x ^ y
count = 0
while z:
z &= z - 1 # 清除最低位的 1
count += 1
return count
漢明距離在計算機科學中有廣泛的應用,例如:
LeetCode 461 題通過位運算的核心技巧,幫助開發者熟悉異或操作和二進制處理。掌握此類問題不僅能提升算法能力,還能加深對計算機底層原理的理解。建議在解題時優先考慮異或結合 Brian Kernighan 算法,以實現高效且簡潔的解決方案。
如若轉載,請注明出處:http://m.0451job.cn/product/56.html
更新時間:2026-02-23 17:41:53