Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

String in scientific notation C++ to double conversion

I've got a database filled up with doubles like the following one:

1.60000000000000000000000000000000000e+01

Does anybody know how to convert a number like that to a double in C++?

Is there a "standard" way to do this type of things? Or do I have to roll my own function?

Right now I'm doing sth like this:

#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;
}

Thanks!

like image 380
miya Avatar asked Nov 10 '09 19:11

miya


2 Answers

Something like this? This would be the "C++" way of doing it...

#include <sstream>
using namespace std;

// ...

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

Prints 16.

like image 127
Thomas Avatar answered Sep 21 '22 07:09

Thomas


You want the standard c function atof ([A]SCII to [F]loat, but it actually uses doubles rather than floats).

like image 44
Russell Newquist Avatar answered Sep 18 '22 07:09

Russell Newquist