Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,870 questions

51,793 answers

573 users

How to check if a number has same number of set and unset bits in Java

1 Answer

0 votes
import java.io.*;  
   
public class MyClass {
    static boolean check_same_set_and_unset_bits(int n) { 
        int set = 0, unset = 0; 
    
        while (n != 0) { 
            if ((n & 1) == 1) 
                set++; 
            else
                unset++; 
            n = n >> 1; 
        } 
        
        if (set == unset) 
            return true; 
        
        return false; 
    }  
    public static void main(String args[]) {
        int n = 178;
  
        System.out.println(Integer.toBinaryString(n)); 
 
        if (check_same_set_and_unset_bits(n)) 
            System.out.println("Yes\n"); 
        else
            System.out.println("No\n"); 
            
        n = 179;
  
        System.out.println(Integer.toBinaryString(n)); 
 
        if (check_same_set_and_unset_bits(n)) 
            System.out.println("Yes\n"); 
        else
            System.out.println("No\n"); 
    }
}
   

   
/*
run:
   
10110010
Yes

10110011
No
  
*/

 



answered Mar 11, 2019 by avibootz
edited Mar 11, 2019 by avibootz

Related questions

...