#include <stdio.h> #include <stdint.h> // Complete the function // uint16_t highest_set_bit(uint16_t reg) // { // for (int i = 15; i >= 0; i--) // { // if (reg & (1U << i)) // { // return (1U << i); // } // } // return 0; // } uint16_t highest_set_bit(uint16_t reg) { for(int i = 15; i >= 0; i--) { if(reg & (1U << i)) { reg &= ~((1U << i)-1); break; } } return reg; } int main() { uint16_t reg; scanf("%hu", ®); uint16_t result = highest_set_bit(reg); printf("%hu", result); return 0; }
Test Cases
Test Results
Input
44
Expected Output
32