将八进制分数转换为十进制 - c ++

时间:2018-01-14 12:41:08

标签: c++ data-conversion fractions

我必须编写一个程序,将八进制分数转换为十进制。 我编写的代码在某些情况下有效,但是对于较小的数字它不起作用,我不知道为什么。

这是我的代码:

int testy,p=0,wykladnik;
    string tmpLiczba;
    string liczba = "";
    long double wynik=0,liczba_dec,wynik_osiem;
    cout << "Podaj liczbe testow:" << endl;
    cin >> testy;
    string *wyniki = new string[testy]; //for later
    for (int i = 0; i < testy; i++)
    {
        cin >> liczba;
        liczba.erase(0, 2);

        for (int j = 0; j < liczba.length();j++)
        {
            tmpLiczba = liczba[j];

            liczba_dec = stoi(tmpLiczba);

            wykladnik = -(j + 1);

            wynik_osiem = pow(8, wykladnik);

            wynik += liczba_dec*wynik_osiem;

        }

        cout << wynik << endl;
        wynik = 0;

    }

(我只得到低于1的数字,所以我可以删除到第一个数字,因为它们根本没有数。) 所以这是我的输入和输出:

输入 - &GT; 0.75

输出 - &GT; 0.953125

输入 - &GT; 0.0001

输出 - &GT; 0.000244141

输入 - &GT; 0.01234567

输出 - &GT; 0.0204081

这些是正确的值,我应该通过这个输入:

0.953125

0.000244140625

0.020408093929290771484375

1 个答案:

答案 0 :(得分:1)

#include <iomanip>
cout << std::setprecision(25) <<wynik << endl;

对于long double,您应该测试size,因为某些编译器使用double作为long double,这不能容纳那么多有效数字。