将八进制分数转换为十进制 - C++
Converting octal fractions to decimal - c++
我必须编写一个将八进制小数转换为十进制的程序。
我写的代码在某些情况下有效,但它不适用于较小的数字,我不知道为什么。
这是我的代码:
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 的数字,所以我可以删除第一位数字,因为它们根本不算数。)
所以这是我的输入和输出:
输入--> 0.75
输出-->0.953125
输入-->0.0001
输出-->0.000244141
输入-->0.01234567
输出-->0.0204081
这些是我应该使用此输入接收的正确值:
0.953125
0.000244140625
0.020408093929290771484375
#include <iomanip>
cout << std::setprecision(25) <<wynik << endl;
对于long double
,你应该测试size
,因为一些编译器使用double
作为long double
,它不能容纳那么多有效数字。
我必须编写一个将八进制小数转换为十进制的程序。 我写的代码在某些情况下有效,但它不适用于较小的数字,我不知道为什么。
这是我的代码:
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 的数字,所以我可以删除第一位数字,因为它们根本不算数。) 所以这是我的输入和输出:
输入--> 0.75
输出-->0.953125
输入-->0.0001
输出-->0.000244141
输入-->0.01234567
输出-->0.0204081
这些是我应该使用此输入接收的正确值:
0.953125
0.000244140625
0.020408093929290771484375
#include <iomanip>
cout << std::setprecision(25) <<wynik << endl;
对于long double
,你应该测试size
,因为一些编译器使用double
作为long double
,它不能容纳那么多有效数字。