#include <stdio.h>
// Function to print 8-bit binary representation
void printBinary8(unsigned int n) {
for (int i = 7; i >= 0; i--) {
printf("%d", (n >> i) & 1);
}
printf("\n");
}
// Function to swap odd and even bits
unsigned int swapsOddAndEvenBits(unsigned int n) {
unsigned int oddBits = n & 0xAAAAAAAA; // (binary: 101010...) to isolate odd bits.
unsigned int evenBits = n & 0x55555555; // (binary: 010101...) to isolate even bits.
printf("oddBits: ");
printBinary8(oddBits);
printf("evenBits: ");
printBinary8(evenBits);
oddBits >>= 1; // Right-shift odd bits by 1 to move them to even positions.
evenBits <<= 1; // Left-shift even bits by 1 to move them to odd positions.
printf("oddBits Right-shift: ");
printBinary8(oddBits);
printf("evenBits Left-shift: ");
printBinary8(evenBits);
return (oddBits | evenBits); // Combine shifted bits
}
int main() {
unsigned int n = 90;
printBinary8(n); // Original number in binary
unsigned int result = swapsOddAndEvenBits(n);
printBinary8(result); // Final result in binary
return 0;
}
/*
run:
01011010
oddBits: 00001010
evenBits: 01010000
oddBits Right-shift: 00000101
evenBits Left-shift: 10100000
10100101
*/