Golang : Check if integer is power of four example
Problem:
You need to test if a given integer is a power of 4. For example, if given number = 16, return true and if number = 9 return false.
Solution:
Test to see if the number can be divided by 4 until it is 1.
package main
import (
"fmt"
"math"
)
func isPowerOfFour(num int) bool {
for num >= 4 {
if num%4 != 0 {
return false
}
num = num / 4
}
return num == 1
}
func main() {
fmt.Println("Is 9 power of 4? : ", isPowerOfFour(9))
fmt.Println("Is 64 power of 4? : ", isPowerOfFour(64))
fmt.Println("Is 8 power of 4? : ", isPowerOfFour(8))
// if use math.Pow() function, remember to convert float64
// to int
testNumPowerOfFour := int(math.Pow(2, 4))
fmt.Println("Is 16 power of 4? : ", isPowerOfFour(testNumPowerOfFour))
testNumPowerOfFour = int(math.Pow(2, 3))
fmt.Println("Is 8 power of 4? : ", isPowerOfFour(testNumPowerOfFour))
}
Output:
Is 9 power of 4? : false
Is 64 power of 4? : true
Is 8 power of 4? : false
Is 16 power of 4? : true
Is 8 power of 4? : false
References:
https://www.socketloop.com/tutorials/golang-math-pow-the-power-of-x-y-example
See also : Golang : Math pow(the power of x^y) example
By Adam Ng
IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.
Advertisement
Tutorials
+15.7k Golang : How to convert(cast) IP address to string?
+3.9k Golang : Switch Redis database redis.NewClient
+12.1k Golang : Decompress zlib file example
+9.1k Golang : Populate or initialize struct with values example
+10.3k Golang : Text file editor (accept input from screen and save to file)
+24.8k Golang : How to print rune, unicode, utf-8 and non-ASCII CJK(Chinese/Japanese/Korean) characters?
+5.8k Javascript : How to refresh page with JQuery ?
+15.2k Golang : package is not in GOROOT during compilation
+10.7k Golang : Allow Cross-Origin Resource Sharing request
+5.5k Unix/Linux : How to archive and compress entire directory ?
+8.3k Golang : HttpRouter multiplexer routing example
+6.6k Golang : Spell checking with ispell example