博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于涉及到浮点数的运算及输出问题
阅读量:6403 次
发布时间:2019-06-23

本文共 1916 字,大约阅读时间需要 6 分钟。

浮点数可以用printf(“%.20f\n”,a);输出到小数点后20位,但是一般的,如果用cout << a << endl; 或者printf("%lf\n",a);这样输出的话,在数据精确度很高的情况下,系统一般会进行四舍五入之后在进行输出,比如说会精确到小数点后六位或者后四位输出。

可以作为参考的题目

如果只是单纯的输出最大最小值记录下来再重新输入到系统的话,得到的数据并不精确,所以会导致问题错位,例如这样:

#include
using namespace std;int main(){ double a[35][35]; memset(a,0,sizeof(a)); for(int i=0;i<30;i++) for(int j=0;j<=i;j++) cin >> a[i][j]; for(int i=1;i<30;i++) { for(int j=0;j<=i;j++) { if(j==0) a[i][j] += a[i-1][j]/2; else if(j==i) a[i][j] += a[i-1][j-1]/2; else a[i][j] += a[i-1][j-1]/2 +a[i-1][j]/2; } } double Max = -1,Min = 1000000; for(int i=29;i<30;i++) { for(int j=0;j<=i;j++) { cout << a[i][j] << " "; if(a[i][j] > Max) Max = a[i][j]; if(a[i][j] < Min) Min = a[i][j]; } } printf("%lf %lf\n",Max,Min); double aa=135.349; double b=3.88633; double x=2086458231; printf("%lf\n",aa*x/b); return 0;}

规范的做法应该是在的到Max还有Min之后,直接用Max还有Min进行运算,而不是输出之后再手动输入(这里确实是本人太太太菜了,才会发生这种低级错误)。以下就是正确的代码:

#include
using namespace std;int main(){ double a[35][35]; memset(a,0,sizeof(a)); for(int i=0;i<30;i++) for(int j=0;j<=i;j++) cin >> a[i][j]; for(int i=1;i<30;i++) { for(int j=0;j<=i;j++) { if(j==0) a[i][j] += a[i-1][j]/2; else if(j==i) a[i][j] += a[i-1][j-1]/2; else a[i][j] += a[i-1][j-1]/2 +a[i-1][j]/2; } } double Max = -1,Min = 1000000; for(int i=29;i<30;i++) { for(int j=0;j<=i;j++) { cout << a[i][j] << " "; if(a[i][j] > Max) Max = a[i][j]; if(a[i][j] < Min) Min = a[i][j]; } } //printf("%.20lf %.20lf\n",Max,Min); double x=2086458231; printf("%lf\n",Max*x/Min); return 0;}

 

转载于:https://www.cnblogs.com/myxdashuaige/p/10510222.html

你可能感兴趣的文章
activator.createinstance 需要垃圾回收么_在垃圾回收器中有哪几种判断是否需要被回收的方法...
查看>>
rocketmq 消息指定_RocketMQ入坑系列(一)角色介绍及基本使用
查看>>
redis zset转set 反序列化失败_掌握好Redis的数据类型,面试心里有底了
查看>>
p图软件pⅰc_娱乐圈最塑料的夫妻,P图永远只P自己,太精彩了吧!
查看>>
jenkins 手动执行_Jenkins 入门
查看>>
怎么判断冠词用a还是an_葡语干货 | 葡萄牙语冠词用法整理大全
查看>>
js传参不是数字_JS的Reflect学习和应用
查看>>
三个不等_数学一轮复习05,从函数观点看方程与不等式,记住口诀与联系
查看>>
右键新建文件夹_Macos电脑鼠标右键木有新建文档咋办,有办法,莫捉急
查看>>
卡尺测量的最小范围_汽车维修工具-测量用具
查看>>
网优5g前景_5G网络优化师前景怎么样?
查看>>
竞态条件的赋值_[译] part25: golang Mutex互斥锁
查看>>
delmatch oracle_完美完全卸载(清除)oracle数据库的方式(方法)
查看>>
pyqt 滚动条 美化_Pyqt5 关于流式布局和滚动条的综合使用示例代码
查看>>
51单机片 编译hex_单片机爬坑记-05-编译环境(完)
查看>>
java 正则表达式 img_Java正则表达式获得html字符串里的<img src=""/> 中的url列表
查看>>
dbutils java_Java篇-DBUtils与连接池
查看>>
java 文件crc校验_一个获取文件crc32校验码的简洁的java类 | 学步园
查看>>
java flatmapfunction_Java8 Stream flatmap中间操作用法解析
查看>>
java rmi spring 4.0_Java Spring RMI一些尝试
查看>>