DEV Community

Prashant Mishra
Prashant Mishra

Posted on

Minimize XOR

Problem

TC : (n+m) where n and m are no. of bits in num1 and num2 respectively


/*
use cases
check if ith bit is set or not
toggle ith bit
count of bits in a number
*/
class Solution {
    public int minimizeXor(int num1, int num2) {
        int c1 = count(num1);
        int c2 = count(num2);
        int number = num1;
        if(c1> c2){

            int i = 0;
            while(c1!=c2){
                //keep on resetting the least significant bits from right to help till c1 == c2
                //check if ith bit is set then unset it and decrement count
                if((number & (1<<i))!=0){
                    number = number ^ (1<<i);// toggle the ith bit
                    c1 = c1-1;
                }
                i++;
            }
        }
        else if (c1 < c2) {
            int i = 0;
            while(c1!=c2){
                //check if the ith bit is 0
                if((number & (1<<i))==0){
                    number = number ^ ( 1<<i); //toggle that bit
                    c1+=1;
                }
                i++;
            }
        }
        return number;
    }
    //count no. of set bits in n
    public int count(int n){
        int count = 0;
        while(n!=0){
            count+=(1&n);
            n = n>>1;
        }
        return count;
    }

}
Enter fullscreen mode Exit fullscreen mode

Do your career a big favor. Join DEV. (The website you're on right now)

It takes one minute, it's free, and is worth it for your career.

Get started

Community matters

Top comments (0)

👋 Kindness is contagious

Dive into an ocean of knowledge with this thought-provoking post, revered deeply within the supportive DEV Community. Developers of all levels are welcome to join and enhance our collective intelligence.

Saying a simple "thank you" can brighten someone's day. Share your gratitude in the comments below!

On DEV, sharing ideas eases our path and fortifies our community connections. Found this helpful? Sending a quick thanks to the author can be profoundly valued.

Okay