给定一个十进制浮点值,你怎么能找到它的小数等价/近似值?例如:
as_fraction(0.1) -> 1/10
as_fraction(0.333333) -> 1/3
as_fraction(514.0/37.0) -> 514/37
是否有可以将十进制数转换为小数形式的通用算法?如何在 C++ 中简单有效地实现这一点?
原文由 Kehlin Swain 发布,翻译遵循 CC BY-SA 4.0 许可协议
给定一个十进制浮点值,你怎么能找到它的小数等价/近似值?例如:
as_fraction(0.1) -> 1/10
as_fraction(0.333333) -> 1/3
as_fraction(514.0/37.0) -> 514/37
是否有可以将十进制数转换为小数形式的通用算法?如何在 C++ 中简单有效地实现这一点?
原文由 Kehlin Swain 发布,翻译遵循 CC BY-SA 4.0 许可协议
3 回答2k 阅读✓ 已解决
2 回答3.9k 阅读✓ 已解决
2 回答3.2k 阅读✓ 已解决
1 回答3.2k 阅读✓ 已解决
1 回答2.7k 阅读✓ 已解决
3 回答3.4k 阅读
1 回答1.6k 阅读✓ 已解决
首先获取小数部分,然后获取 gcd。使用欧几里得算法 http://en.wikipedia.org/wiki/Euclidean_algorithm