Llega el turno del lenguaje de programación Go o GoLang para escribir el algoritmo que determine si un número es narcisista.
Si quieres conocer más sobre el tema, lee: algoritmo para calcular número narcisista.
De nuevo traigo una función para solucionar este ejercicio. Es la siguiente:
func esNarcisista(numero int) bool{
numeroComoCadena := strconv.Itoa(numero)
longitudDeNumero := len(numeroComoCadena)
suma := 0
for indice := 0; indice < longitudDeNumero; indice++{
// Convertir carácter a entero
cifraActual := numeroComoCadena[indice] - '0'
/*
Elevarlo al exponente dado por la longitud del número
por cierto, se castea a float64 porque math.Pow necesita un float64
*/ elevado := math.Pow(float64(cifraActual), float64(longitudDeNumero))
// Vamos sumando el resultado
suma = suma + int(elevado)
}
// Finalmente comprobamos si el número es igual a la suma
if suma == numero{
return true
}else{
return false
}
}
Usamos math.Pow
para elevar números a una potencia, así como strconv.Itoa
para convertir un entero a una cadena, y finalmente a len
para determinar la longitud de una cadena.
Para convertir cada carácter del número a un entero le restamos ‘0’ a dicho carácter, eso nos dará su representación numérica en lugar de su representación en el código ASCII.
La función recibe un entero y devuelve un booleano; así de fácil. Por lo tanto un código completo de su implementación podría ser este:
/*
Determinar si un número es narcisista usando Go/Golang
parzibyte.me/blog
*/package main
import(
"fmt"
"math"
"strconv"
)
func main(){
/*
Aquí probamos un arreglo de números, la función está más abajo
*/ numeros := []int{1, 2, 3, 4, 153, 28, 11, 96, 407, 1634, 54748}
for _, numero := range numeros{
fmt.Printf("¿%d es narcisista? %t\n", numero, esNarcisista(numero))
}
}
// Aquí la función
func esNarcisista(numero int) bool{
numeroComoCadena := strconv.Itoa(numero)
longitudDeNumero := len(numeroComoCadena)
suma := 0
for indice := 0; indice < longitudDeNumero; indice++{
// Convertir carácter a entero
cifraActual := numeroComoCadena[indice] - '0'
/*
Elevarlo al exponente dado por la longitud del número
por cierto, se castea a float64 porque math.Pow necesita un float64
*/ elevado := math.Pow(float64(cifraActual), float64(longitudDeNumero))
// Vamos sumando el resultado
suma = suma + int(elevado)
}
// Finalmente comprobamos si el número es igual a la suma
if suma == numero{
return true
}else{
return false
}
}
En este caso probamos todo un arreglo de números e imprimimos los resultados en pantalla. La salida se ve a continuación:
El día de hoy te mostraré cómo crear un servidor HTTP (servidor web) en Android…
En este post te voy a enseñar a designar una carpeta para imprimir todos los…
En este artículo te voy a enseñar la guía para imprimir en una impresora térmica…
Hoy te voy a mostrar un ejemplo de programación para agregar un módulo de tasa…
Los usuarios del plugin para impresoras térmicas pueden contratar licencias, y en ocasiones me han…
Hoy voy a enseñarte cómo imprimir el € en una impresora térmica. Vamos a ver…
Esta web usa cookies.
Ver comentarios