Cuando uso% operator en valores float obtengo un error que indica que "operandos inválidos a% binario (tienen 'float' y 'double')". Quiero ingresar los enteros solo valor, pero los números son muy grandes (no están en el rango de tipo int) así que para evitar el inconveniente utilizo float. ¿Hay alguna forma de usar% operator en valores enteros tan grandes ????Cómo usar el operador% para valores float en c
Respuesta
Puede usar la función fmod
de la biblioteca matemática estándar. Su prototipo está en el encabezado estándar <math.h>
.
Probablemente sea mejor que use long long
, que tiene una precisión mayor que double
en la mayoría de los sistemas.
Nota: Si sus números son más grandes que long long
puede contener, entonces fmod
probablemente no se comportará de la manera que desee. En ese caso, la mejor opción es una biblioteca bigint, como this one.
BigIntegerLibrary no se acepta en c ??? Además, ¿cuál es el% especificador para entero grande ??? –
Lo siento, la biblioteca que sugerí es C++. –
consideran: int de 32 bits y largo long int de 64 bits
Sí,% (módulo) del operador no es el trabajo con los flotadores y doble .. si usted quiere hacer la operación de módulo en gran número se puede cheque long long int(64bits)
podría esto ayudarlo.
aún el rango más de 64 bits, entonces en ese caso necesita almacenar los datos en ... cadena y hacer el funcionamiento del módulo de forma algorítmica.
o bien se puede ir a cualquier lenguaje de programación como Python
El operador %
sólo está definido para operandos de tipo entero; que necesita para utilizar las funciones de biblioteca fmod*
para este tipo de punto flotante:
#include <math.h>
double fmod(double x, double y);
float fmodf(float x, float y);
long double fmodl(long double x, long double y);
Si desea utilizar un uso int largo tiempo, no utilice un formato que no es ideal para su problema si una mejor formato existe.
Cuando no he tenido fácil acceso a fmod
u otras bibliotecas (por ejemplo, haciendo un boceto Arduino rápida), considero que los siguientes funciona bastante bien:
float someValue = 0.0;
// later...
// Since someValue = (someValue + 1) % 256 won't work for floats...
someValue += 1.0; // (or whatever increment you want to use)
while (someValue >= 256.0){
someValue -= 256.0;
}
- 1. Cómo usar expr en float?
- 2. ¿Por qué usar el operador Bitwise-Shift para valores en una definición de C enum?
- 3. ¿Puedo usar el operador [] en C++ para crear matrices virtuales
- 4. Objetivo-c: ¿Cómo redondear los valores de Float?
- 5. operador sizeof devuelve diferentes valores para c & C++?
- 6. ¿Cómo usar el operador ternario de C# con dos valores de byte?
- 7. JFreeChart Muestra valores enteros como float en el Y-Axis
- 8. ¿Usar el operador ternario para inicializar una variable de referencia?
- 9. Usar el operador ternario para operaciones múltiples
- 10. C# analógico para SQL en el operador
- 11. ¿Cuándo debemos usar el operador verificado en C#?
- 12. Objective-C Float redondeo
- 13. Si un operador está sobrecargado para una clase de C++, ¿cómo podría usar un operador predeterminado?
- 14. C++ múltiples sobrecargas de operador para el mismo operador
- 15. Div colapsar al usar float
- 16. ¿Cómo el operador C == decide si dos valores de coma flotante son iguales o no?
- 17. Agregar dos matrices de valores float en Haskell
- 18. Cómo utilizar el operador ternario para esta declaración en C#
- 19. ¿Cómo funciona el operador unario negativo en booleanos en C++?
- 20. operador + para matrices en C++
- 21. ¿Cómo sobrecargar el operador [] en C#
- 22. C++ float to int
- 23. Ordenar una columna VARCHAR como FLOAT con el operador CAST no funciona en MySQL
- 24. C# en el operador-sobrecarga
- 25. no operador en C++ para int?
- 26. ¿Puedo usar el operador 'y' en xsl para cada uno?
- 27. ¿Cómo usar la matriz php con el operador sql IN?
- 28. Ternario? operador contra el operador convencional Si-else en C#
- 29. Convierte float [] en byte [] en float [] nuevamente
- 30. C# 'insegura' función - * (float *) (& resultado) vs (float) (resultado)
Así 1,5% 1,1 = 0,4? – StuartLC
sí división de módulo a = b% c; no funcionaría, porque no puede obtener un resto dividiendo un decimal por un decimal. –