web-dev-qa-db-fra.com

Vous ne pouvez pas utiliser le module sur les doubles?

J'ai un programme en C++ (compilé avec g ++). J'essaie d'appliquer deux doubles comme opérandes à la fonction de module, mais j'obtiens l'erreur suivante:

erreur: opérandes non valides des types "double" et "double" en "opérateur%" binaire

Voici le code:

int main() {
    double x = 6.3;
    double y = 2;
    double z = x % y;
}
170
Bhaxy

L'opérateur % concerne les entiers. Vous recherchez la fonction fmod() .

#include <cmath>

int main()
{
    double x = 6.3;
    double y = 2.0;
    double z = std::fmod(x,y);

}
255
Mysticial

fmod(x, y) est la fonction que vous utilisez.

36
MSN

Utilisez fmod() à partir de <cmath>. Si vous ne souhaitez pas inclure le fichier d'en-tête C:

template<typename T, typename U>
constexpr double dmod (T x, U mod)
{
    return !mod ? x : x - mod * static_cast<long long>(x / mod);
}

//Usage:
double z = dmod<double, unsigned int>(14.3, 4);
double z = dmod<long, float>(14, 4.6);
//This also works:
double z = dmod(14.7, 0.3);
double z = dmod(14.7, 0);
double z = dmod(0, 0.3f);
double z = dmod(myFirstVariable, someOtherVariable);
5
Sceptical Jule