我有一个程序在c++(编译使用g++)。我试图应用两个双精度作为模函数的操作数,但我得到以下错误:
错误:类型为'double'和'double'的操作数对二进制'运算符%'无效
代码如下:
int main() {
double x = 6.3;
double y = 2;
double z = x % y;
}
我有一个程序在c++(编译使用g++)。我试图应用两个双精度作为模函数的操作数,但我得到以下错误:
错误:类型为'double'和'double'的操作数对二进制'运算符%'无效
代码如下:
int main() {
double x = 6.3;
double y = 2;
double z = x % y;
}
当前回答
使用fmod() from <cmath>。如果你不想包含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);
其他回答
你可以实现你自己的模函数来做这件事:
double dmod(double x, double y) {
return x - (int)(x/y) * y;
}
然后,您可以简单地使用dmod(6.3, 2)来获得余数0.3。
使用fmod() from <cmath>。如果你不想包含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);
Fmod (x, y)是你使用的函数。
%操作符用于整数。您正在寻找fmod()函数。
#include <cmath>
int main()
{
double x = 6.3;
double y = 2.0;
double z = std::fmod(x,y);
}