c++float浮点数比较大小
时间: 2023-07-24 19:05:56 浏览: 286
浮点数比较大小.c
在C++中,使用浮点数比较大小时需要注意精度问题。由于浮点数使用二进制表示,因此存在精度损失的问题。比较两个浮点数大小时,可以先将它们相减,然后与一个很小的数(例如1e-6)进行比较,如果差值小于这个很小的数,则认为它们相等,否则就可以根据差值的正负判断大小关系。
下面是一个示例代码:
```c++
#include <iostream>
#include <cmath>
using namespace std;
bool cmp(float a, float b) {
if (fabs(a - b) < 1e-6) {
return true; // 两者相等
}
return a < b;
}
int main() {
float a = 1.23, b = 2.34;
if (cmp(a, b)) {
cout << "a < b" << endl;
} else {
cout << "a >= b" << endl;
}
return 0;
}
```
在上面的示例代码中,cmp函数比较了两个浮点数的大小,如果它们相等则返回true,否则根据差值的正负判断大小关系。在主函数中,我们调用cmp函数比较了a和b的大小。
阅读全文