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

1 Answer

0 votes
package main

import (
    "fmt"
    "math/bits"
)

// roundToNearestPowerOf2 returns the power of 2 closest to n.
func roundToNearestPowerOf2(n uint32) uint32 {
    if n == 0 {
        return 0
    }

    // Compute the previous power of 2 using leading zero count
    prev := uint32(1) << (31 - bits.LeadingZeros32(n))
    next := prev << 1

    if n-prev < next-n {
        return prev
    }
    
    return next
}

func main() {
    num := uint32(37)
    
    fmt.Printf("Nearest power of 2: %d\n", roundToNearestPowerOf2(num))
}


/*
run:

Nearest power of 2: 32

*/

 



answered Oct 31, 2025 by avibootz

Related questions

1 answer 82 views
1 answer 72 views
1 answer 108 views
1 answer 173 views
1 answer 173 views
1 answer 84 views
...