我必须编写一个程序,将八进制分数转换为十进制。 我编写的代码在某些情况下有效,但是对于较小的数字它不起作用,我不知道为什么。
这是我的代码:
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
答案 0 :(得分:1)
#include <iomanip>
cout << std::setprecision(25) <<wynik << endl;
对于long double
,您应该测试size
,因为某些编译器使用double
作为long double
,这不能容纳那么多有效数字。