-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSolution.java
34 lines (30 loc) · 915 Bytes
/
Solution.java
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
// https://leetcode.com/problems/complement-of-base-10-integer
class Solution {
public int bitwiseComplement(int N) {
if(N == 0) return 1;
return convertToDecimal(complement(convertToBinary(N)));
}
public ArrayList<Integer> convertToBinary(int num){
ArrayList<Integer> binary = new ArrayList<>();
while(num > 0){
binary.add(num % 2);
num /= 2;
}
return binary;
}
public int convertToDecimal(ArrayList<Integer> binary){
int num = 0;
int pow = 1;
for(int i=0;i<binary.size();i++){
num += binary.get(i) * pow;
pow *= 2;
}
return num;
}
public ArrayList<Integer> complement(ArrayList<Integer> binary){
for(int i=0;i<binary.size();i++){
binary.set(i, binary.get(i) == 0 ? 1 : 0);
}
return binary;
}
}