How to round a number to the nearest power of 2 in PHP

2 Answers

0 votes
/**
 * Rounds an integer to the nearest power of 2.
 *
 * return int The nearest power of 2
 */
function roundToNearestPowerOf2(int $n): int {
    if ($n <= 0) {
        return 0;
    }

    $prevPower = 1;
    while ($prevPower << 1 <= $n) {
        $prevPower <<= 1;
    }

    $nextPower = $prevPower << 1;

    return ($n - $prevPower < $nextPower - $n) ? $prevPower : $nextPower;
}

$num = 37;

echo "Nearest power of 2: " . roundToNearestPowerOf2($num) . PHP_EOL;


/*
run:

Nearest power of 2: 32

*/

 



answered Oct 31, 2025 by avibootz
0 votes
function roundToNearestPowerOf2(int $n): int {
    if ($n <= 0) {
        return 0;
    }

    // Compute the previous power of 2 using bit length
    $prevPower = 1 << (int)floor(log($n, 2));

    // Compute the next power of 2
    $nextPower = $prevPower << 1;

    // Return the one closest to n
    return ($n - $prevPower < $nextPower - $n) ? $prevPower : $nextPower;
}

$num = 37;

echo "Nearest power of 2: " . roundToNearestPowerOf2($num) . PHP_EOL;



/*
run:

Nearest power of 2: 32

*/

 



answered Oct 31, 2025 by avibootz

Related questions

1 answer 59 views
3 answers 201 views
1 answer 148 views
1 answer 85 views
1 answer 98 views
1 answer 85 views
...