https://hadesmercury.blogspot.com/2019/03/bitwise-operator-basics.html
More Bit Manipulation Problems:
https://leetcode.com/tag/bit-manipulation/
Q342 Power of Four
Given an integer (signed 32 bits), write a function to check whether it is a power of 4.
Sample solution:
https://github.com/Sylvia-YiyinShen/Algorithm/blob/master/BitManipulation/Q342PowerOfFour.playground/Contents.swift
num: 4 binary: 00000100
num: 16 binary: 00010000
num: 64 binary: 01000000
Similar approach to solve Power of Two. But the difference is the how many bits we care.
Solving Power of Four we care about 3 bits, if the last 3 bits is '100', so instead of & 1 to check the last 3 bits, we use '& 7' (& 111) and we count the number of '100' we have found
if it is '100' we increase the count, return false if the count > 1
if it is '000' we can shift right by 2
if it is other value besides of '100' or '000', then it can not be a power of 4, return false directly
data:image/s3,"s3://crabby-images/d62e0/d62e08d295a08a6040cb6fce92006804773aab3e" alt=""
We will be able to find another solution by introducing 0x55555555,
0x55555555 = 0101 0101 ... 0101
0xaaaaaaaa = 1010 1010 ... 1010
For a power of 4: n, n & 0x55555555 should be n
data:image/s3,"s3://crabby-images/8a111/8a111c19c1778f4b1f8c287ecd031ac16e44bacc" alt=""
Other solutions, I am not going to cover so much in this page
data:image/s3,"s3://crabby-images/59749/59749a6177afe63d1938b13e2f2568e24a99fbb9" alt=""
The last solution based on the formula, however the solution doesn't work in Swift neither in Java. Try C++.
data:image/s3,"s3://crabby-images/32e43/32e433737f82f15bb5a7138e55f7c02dde3a6df9" alt=""
data:image/s3,"s3://crabby-images/5e26b/5e26b625aaabb4ec44005145da3844b0c5ce5e97" alt=""
No comments:
Post a Comment