JavaAlgorithms/Others/BrianKernighanAlgorithm.java

50 lines
1.2 KiB
Java
Raw Normal View History

package Others;
2017-12-30 04:41:15 +08:00
import java.util.Scanner;
/**
* @author Nishita Aggarwal
* <p>
2017-12-30 04:44:48 +08:00
* Brian Kernighans Algorithm
* <p>
2017-12-30 04:41:15 +08:00
* algorithm to count the number of set bits in a given number
* <p>
2017-12-31 22:47:51 +08:00
* Subtraction of 1 from a number toggles all the bits (from right to left) till the rightmost set bit(including the
* rightmost set bit).
* So if we subtract a number by 1 and do bitwise & with itself i.e. (n & (n-1)), we unset the rightmost set bit.
* <p>
2017-12-31 22:47:51 +08:00
* If we do n & (n-1) in a loop and count the no of times loop executes we get the set bit count.
* <p>
* <p>
2017-12-30 04:41:15 +08:00
* Time Complexity: O(logn)
*/
public class BrianKernighanAlgorithm {
/**
* @param num: number in which we count the set bits
* @return int: Number of set bits
*/
static int countSetBits(int num) {
int cnt = 0;
while (num != 0) {
num = num & (num - 1);
cnt++;
}
return cnt;
}
/**
* @param args : command line arguments
*/
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int num = sc.nextInt();
int setBitCount = countSetBits(num);
System.out.println(setBitCount);
sc.close();
}
2017-12-30 04:41:15 +08:00
}