round() for float in C++(在 C++ 中用于浮点数的 round())
问题描述
我需要一个简单的浮点舍入函数,因此:
I need a simple floating point rounding function, thus:
double round(double);
round(0.1) = 0
round(-0.1) = 0
round(-0.9) = -1
我可以在 math.h 中找到 ceil() 和 floor() - 但不是 round().
I can find ceil() and floor() in the math.h - but not round().
它是否以另一个名称存在于标准 C++ 库中,还是丢失了??
Is it present in the standard C++ library under another name, or is it missing??
推荐答案
cmath C++11 起可用(根据http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2012/n3337.pdf)
It's available since C++11 in cmath (according to http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2012/n3337.pdf)
#include <cmath>
#include <iostream>
int main(int argc, char** argv) {
std::cout << "round(0.5): " << round(0.5) << std::endl;
std::cout << "round(-0.5): " << round(-0.5) << std::endl;
std::cout << "round(1.4): " << round(1.4) << std::endl;
std::cout << "round(-1.4): " << round(-1.4) << std::endl;
std::cout << "round(1.6): " << round(1.6) << std::endl;
std::cout << "round(-1.6): " << round(-1.6) << std::endl;
return 0;
}
输出:
round(0.5): 1
round(-0.5): -1
round(1.4): 1
round(-1.4): -1
round(1.6): 2
round(-1.6): -2
这篇关于在 C++ 中用于浮点数的 round()的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在 C++ 中用于浮点数的 round()
基础教程推荐
- 为什么 RegOpenKeyEx() 在 Vista 64 位上返回错误代码 2021-01-01
- 非静态 const 成员,不能使用默认赋值运算符 2022-10-09
- 如果我为无符号变量分配负值会发生什么? 2022-01-01
- 为什么派生模板类不能访问基模板类的标识符? 2021-01-01
- GDB 显示调用堆栈上函数地址的当前编译二进制文 2022-09-05
- 我应该对 C++ 中的成员变量和函数参数使用相同的名称吗? 2021-01-01
- 通过引用传递 C++ 迭代器有什么问题? 2022-01-01
- 初始化列表*参数*评估顺序 2021-01-01
- 为什么 typeid.name() 使用 GCC 返回奇怪的字符以及如 2022-09-16
- CString 到 char* 2021-01-01
