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