关于 pow 浮点精度丢失
2023-03-14 10:17:38 时间
/* 寝室学弟问我一个很简单的问题,就是把一个数逆序后输出的字符串转换为数值, 学弟用了pow这个很常见的函数,代码逻辑没有问题,但是不理解为什么答案是错的, 而且只差1或者2;在小蒙的帮助下,才开始意识到pow 精度丢失的问题. 一查 cplusplus.com 才发现 如下问题: double pow ( double base, double exponent ); long double pow ( long double base, long double exponent ); float pow ( float base, float exponent ); double pow ( double base, int exponent ); long double pow ( long double base, int exponent ); pow函数不存在pow(int int),也就是说输入的pow(10,n)中的10 会先转换为double 这样一来数字大了误差就大了 导致了错误;看来平时常用的函数也要注意细节! */ #include<stdio.h> #include <math.h> int a[1000]; int main() { int i,x,n=0,t,sum=0,j=0; scanf("%d",&i); x=i; printf("逆序为:"); while(x) { t=x%10; printf("%d",t); a[j++]=t; x/=10; } printf("\n"); /* for(int i = 0; i<j; i++) sum = sum*10+a[i]; */ while(j>=0) { --j; sum+=a[j]*((int)(pow(10,n)+0.5)); //这里如果不加0.5进行四舍五入int强转 会导致精度丢失 n++; } printf("sum=%d\n",sum); return 0; }
相关文章
- 在 Go 里用 CGO?这 7 个问题你要关注!
- 9款优秀的去中心化通讯软件 Matrix 的客户端
- 求职数据分析,项目经验该怎么写
- 在OKR中,我看到了数据驱动业务的未来
- 火山引擎云原生大数据在金融行业的实践
- OpenHarmony富设备移植指南(二)—从postmarketOS获取移植资源
- 《数据成熟度指数》报告:64%的企业领袖认为大多数员工“不懂数据”
- OpenHarmony 小型系统兼容性测试指南
- 肯睿中国(Cloudera):2023年企业数字战略三大趋势预测
- 适用于 Linux 的十大命令行游戏
- GNOME 截图工具的新旧截图方式
- System76 即将推出的 COSMIC 桌面正在酝酿大变化
- 2GB 内存 8GB 存储即可流畅运行,Windows 11 极致精简版系统 Tiny11 发布
- 迎接 ecode:一个即将推出的具有全新图形用户界面框架的现代、轻量级代码编辑器
- loongarch架构介绍(三)—地址翻译
- Go 语言怎么解决编译器错误“err is shadowed during return”?
- 敏捷:可能被开发人员遗忘的部分
- Denodo预测2023年数据管理和分析的未来
- 利用数据推动可持续发展
- 在 Vue3 中实现 React 原生 Hooks(useState、useEffect),深入理解 React Hooks 的