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,914 questions

51,847 answers

573 users

How to swap all odd and even bits in PHP

1 Answer

0 votes
class BitManipulation
{
    /**
     * Prints the 8-bit binary representation of an integer.
     */
    public static function printBinary(int $value): void {
        // Mask with 0xFF to ensure only 8 bits are printed
        $binary = str_pad(decbin($value & 0xFF), 8, '0', STR_PAD_LEFT);
        echo $binary . PHP_EOL;
    }

    /**
     * Swaps odd and even bits in a 32-bit integer.
     */
    public static function swapOddAndEvenBits(int $n): int {
        // (binary: 101010...) to isolate odd bits.
        $oddBits = $n & 0xAAAAAAAA;

        // (binary: 010101...) to isolate even bits.
        $evenBits = $n & 0x55555555;

        echo "oddBits:  ";
        self::printBinary($oddBits);

        echo "evenBits: ";
        self::printBinary($evenBits);

        // Right-shift odd bits by 1 to move them to even positions.
        $oddBits >>= 1;

        // Left-shift even bits by 1 to move them to odd positions.
        $evenBits <<= 1;

        echo "oddBits Right-shift: ";
        self::printBinary($oddBits);

        echo "evenBits Left-shift: ";
        self::printBinary($evenBits);

        // Combine shifted bits
        return $oddBits | $evenBits;
    }
}

$n = 90;

// Original number in binary
BitManipulation::printBinary($n);

$result = BitManipulation::swapOddAndEvenBits($n);

// Final result in binary
BitManipulation::printBinary($result);



/*
run:

01011010
oddBits:  00001010
evenBits: 01010000
oddBits Right-shift: 00000101
evenBits Left-shift: 10100000
10100101

*/

 



answered Oct 26, 2025 by avibootz
edited Oct 26, 2025 by avibootz

Related questions

1 answer 49 views
1 answer 120 views
1 answer 48 views
1 answer 56 views
...