-
Notifications
You must be signed in to change notification settings - Fork 118
/
Copy path477. Total Hamming Distance.cpp
57 lines (49 loc) · 1.38 KB
/
477. Total Hamming Distance.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
//TLE
//38 / 47 test cases passed.
class Solution {
public:
int count_set_bit(int x){
int bits = 0;
while(x != 0){
bits += x&1;
x >>= 1;
}
return bits;
}
int totalHammingDistance(vector<int>& nums) {
int N = nums.size();
int ans = 0;
for(int i = 0; i < N-1; i++){
for(int j = i+1; j < N; j++){
int xorResult = nums[i]^nums[j];
ans += count_set_bit(xorResult);
}
}
return ans;
}
};
//iterate from MSB
//https://leetcode.com/problems/total-hamming-distance/discuss/96226/Java-O(n)-time-O(1)-Space
//Runtime: 88 ms, faster than 10.31% of C++ online submissions for Total Hamming Distance.
//Memory Usage: 8 MB, less than 100.00% of C++ online submissions for Total Hamming Distance.
//time: O(N), space: O(1)
class Solution {
public:
int totalHammingDistance(vector<int>& nums) {
int N = nums.size();
int ans = 0;
for(int i = 31; i >= 0; i--){
int mask = 1 << i;
int set = 0, noset = 0;
for(int num : nums){
if(num & mask){
set++;
}else{
noset++;
}
}
ans += set*noset;
}
return ans;
}
};