-
Notifications
You must be signed in to change notification settings - Fork 19.9k
/
Copy pathIsPowerTwo.java
32 lines (30 loc) · 1.07 KB
/
IsPowerTwo.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
package com.thealgorithms.bitmanipulation;
/**
* Utility class for checking if a number is a power of two.
* A power of two is a number that can be expressed as 2^n where n is a non-negative integer.
* This class provides a method to determine if a given integer is a power of two using bit manipulation.
*
* @author Bama Charan Chhandogi (https://github.com/BamaCharanChhandogi)
*/
public final class IsPowerTwo {
private IsPowerTwo() {
}
/**
* Checks if the given integer is a power of two.
*
* A number is considered a power of two if it is greater than zero and
* has exactly one '1' bit in its binary representation. This method
* uses the property that for any power of two (n), the expression
* (n & (n - 1)) will be zero.
*
* @param number the integer to check
* @return true if the number is a power of two, false otherwise
*/
public static boolean isPowerTwo(int number) {
if (number <= 0) {
return false;
}
int ans = number & (number - 1);
return ans == 0;
}
}