科学记数法中的字符串C ++以双重转换

时间:2009-11-10 19:12:20

标签: c++ math type-conversion scientific-notation

我有一个数据库充满了下面的双打:

1.60000000000000000000000000000000000e+01

有人知道如何在C ++中将这样的数字转换为double吗?

是否有“标准”方式来做这类事情?或者我必须自己动手?

现在我正在做这样的事情:

#include <string>
#include <sstream>



int main() {
    std::string s("1.60000000000000000000000000000000000e+01");
    std::istringstream iss(s);
    double d;
    iss >> d;
    d += 10.303030;
    std::cout << d << std::endl;
}

谢谢!

2 个答案:

答案 0 :(得分:17)

这样的东西?这将是“C ++”的做法......

#include <sstream>
using namespace std;

// ...

    string s = "1.60000000000000000000000000000000000e+01";
    istringstream os(s);
    double d;
    os >> d;
    cout << d << endl;

打印16。

答案 1 :(得分:11)

你想要标准c函数atof([A] SCII到[F] loat,但实际上它使用的是双精度而不是浮点数。)