解析C++ 浮点数的格式化显示
时间:2020-10-21 20:45:55|栏目:C代码|点击: 次
代码如下所示:
#include <stdlib.h>
#include <string>
#include <windows.h>
#include <stdio.h>
#include <iostream>
#include <limits>
#include <sstream>
using namespace std;
string do_fraction(long double val, int decplaces=3)
{
ostringstream out;
char DECIMAL_POINT='.'; // 欧洲用法为','
int prec=numeric_limits<long double>::digits10; // 18
out.precision(prec);//覆盖默认精度
out<<val;
string str= out.str(); //从流中取出字符串
size_t n=str.find(DECIMAL_POINT);
if ((n!=string::npos) //有小数点吗?
&& (str.size()> n+decplaces)) //后面至少还有decplaces位吗?
{
str[n+decplaces]='\0';//覆盖第一个多余的数
}
str.swap(string(str.c_str()));//删除nul之后的多余字符
return str;
}
复制代码 代码如下:
#include <stdlib.h>
#include <string>
#include <windows.h>
#include <stdio.h>
#include <iostream>
#include <limits>
#include <sstream>
using namespace std;
string do_fraction(long double val, int decplaces=3)
{
ostringstream out;
char DECIMAL_POINT='.'; // 欧洲用法为','
int prec=numeric_limits<long double>::digits10; // 18
out.precision(prec);//覆盖默认精度
out<<val;
string str= out.str(); //从流中取出字符串
size_t n=str.find(DECIMAL_POINT);
if ((n!=string::npos) //有小数点吗?
&& (str.size()> n+decplaces)) //后面至少还有decplaces位吗?
{
str[n+decplaces]='\0';//覆盖第一个多余的数
}
str.swap(string(str.c_str()));//删除nul之后的多余字符
return str;
}
上一篇:C语言求Fibonacci斐波那契数列通项问题的解法总结
栏 目:C代码
下一篇:C++ operator关键字(重载操作符)的用法详解
本文标题:解析C++ 浮点数的格式化显示
本文地址:http://www.codeinn.net/misctech/14419.html