Hoy vamos a ver cómo usar la función modf en C para separar la parte entera y la parte decimal de un número.
Por ejemplo, a partir del número 123.45 vamos a separar el 123 y el 0.45, todo como números, no con cadenas. En otras palabras vamos a descomponer el número en parte entera y parte fraccionaria.
Función modf
Esta se encuentra en math.h, inclúyela con:
include <math.h>
La sintaxis es:
double parteFraccional = modf(numeroQueVamosADescomponer, apuntadorAParteEntera);
Primero es un poco complicada pero si leemos bien veremos que es fácil. Como una función en C no puede devolver dos valores, lo que hace es devolver la parte fraccional y poner en el apuntador la parte entera.
Ya veremos cómo es de fácil con los ejemplos.
Separar parte entera y decimal con C
Ahora sí a lo que venimos. Veamos el siguiente código:
#include <stdio.h> // printf
#include <math.h> // modf
int main(void) {
double numero = 123.45;
printf("El número es %f\n", numero);
// En las siguientes almacenamos las partes separadas
double parteDecimal, parteEntera;
parteDecimal = modf(numero, &parteEntera); // mandar apuntador de parteEntera
// modf devuelve la parte decimal, y pone la parte entera en la variable cuya dirección mandamos
printf("Parte entera: %f. Parte decimal: %f\n", parteEntera, parteDecimal);
return 0;
}
La salida es:
El número es 123.450000
Parte entera: 123.000000. Parte decimal: 0.450000
Como vemos ha separado la parte decimal y la parte entera. Cabe mencionar que se trabaja con números de tipo double para tener la mayor precisión.
Alternativa a modf
Si nos confunde la función, podemos ir por las simples matemáticas. Para sacar la parte entera, convertimos el número a entero.
Y para sacar la parte decimal, restamos el número entero del original. Así como el ejemplo:
#include <stdio.h> // printf
int main(void) {
double numero = 123.45;
printf("El número es %f\n", numero);
int parteEntera = (int) numero;
double parteDecimal = numero - parteEntera;
printf("Parte entera: %d. Parte decimal: %f\n", parteEntera, parteDecimal);
return 0;
}
La desventaja es que podríamos perder precisión por los límites de los enteros, por eso se recomienda usar modf.
Pingback: Obtener parte decimal y entera de número con Python - Parzibyte's blog