新微赢技术网

标题: 请问C++中如何去小数点后两位呀? [打印本页]

作者: 天语悠悠    时间: 2009-11-3 01:37
标题: 请问C++中如何去小数点后两位呀?
例如我已经有一个double值3.14532,如果我想得到它的四舍五入值3.15(也要是double型的),程序该如何写呢?或者不用四舍五入,直接去到3.14,程序有该怎么写呀?有现成的方法可以调用吗?谢谢
作者: 停淼心泪    时间: 2009-11-3 01:37
#include<iostream>
using namespace std;
int main()
{
double x,y;int z,ans;
cout<<"Enter a double number: ";
cin>>x;
y=x*1000;
ans=int(y);
z=ans%10;
if(z<5)ans-=z;
else ans=ans-z+10;
cout<<fixed<<double(ans)/1000<<endl;
systerm("pause");
return 0;
}
没编译,没调试,没检查错误,你自己去编,试试。
作者: √死胖子    时间: 2009-11-3 01:37
这个我也不懂哦!我是初学.只能看懂前面一点点,后面也不知道哦,wfpb讲解一下哈...呵呵
作者: liu    时间: 2009-11-3 01:37
比如输入的数是:3.14159。
则x=3.14159;
然后y=3.14159*1000就等于:3141.59.//这里是求2位有效数的4舍5入,所以乘1000。
然后用强制类型转换,ans=int(y);就有ans=3141;
然后看z=ans%10;就是求ans中最后一位数的值,这里是1;
然后根据这个值来四舍五入。如果大于5就进1,小于5就省略。
然后在把得到的新的ans强制类型转换再除以1000,double(ans)/1000;
得到最后的答案。
//注意,我也是菜鸟。
作者: ﹫.★…ㄨ★    时间: 2009-11-3 01:37
使用#include"iostream.h"里面有个setprecision格式控制符,可以控制有效数字位数.
我好不容易翻书找到的呦!
作者: v九天〓云龙    时间: 2009-11-3 01:37
到了STL就变为了precision了。
#include <iostream>
using namespace std;
void main()
{
float i=3.14159;
cout.precision(3);
cout<<i<<endl;
}
结果就为3.14.
//我也是很菜的。
作者: 紫色&飘蓝ぁ    时间: 2009-11-3 01:37
以下是引用踏魔狼在2006-4-24 22:34:00的发言:

到了STL就变为了precision了。
#include <iostream>
using namespace std;
void main()
{
float i=3.14159;
cout.precision(3);
cout<<i<<endl;
}
结果就为3.14.
//我也是很菜的。
你也太过分了
是不是讽刺我们呢
作者: 痴人痴想    时间: 2009-11-3 01:37
请问六楼的,precision 是做什么的?
谢谢,我很菜
作者: ~~真累~~    时间: 2009-11-3 01:37
其实C的格式会比C++的cout简单,MFC的Format也同样方便,不知道STL里面为什么搞个percision,这么不方便。
#include "stdafx.h"
#include <iostream>
using namespace std;
int main(int argc, char *argv[])
{
float fPi = (float)3.14532;
printf("%.2f\n", fPi);

cout.precision(3);
cout << fPi << endl;
return 0;
}
作者: ˊ.龙之吻︷    时间: 2009-11-3 01:37
#include<iomanip>//重要的头文件
#include<iostream>
#include<cmath>
using namespace std;
int main(){
cout<<fixed<<setprecision(2)<<M_PI<<endl;
}




欢迎光临 新微赢技术网 (http://bbs.weiying.cn/) Powered by Discuz! X3.2