Неправильные результаты точности с std::ostingstreamC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Неправильные результаты точности с std::ostingstream

Сообщение Anonymous »

Мне нужен способ выполнения основных математических операций (таких как sum, sub, div и mul, sqr/sqrt и т. д.) с базовыми строками, чтобы получить расширенную точность, например более длинные десятичные цифры.
Я пытался выполнить простое сложение, вычитание, умножение и деление с помощью std::ostringstream, чтобы получить более длинные десятичные цифры, и вначале это работало очень хорошо, но позже я понял, что результаты были неточными и по какой-то причине чем больше получаются числа (или длиннее десятичные дроби), тем меньше получается результат. Например; -23 440 981,5645656787684654675677634 x 3 454 561,56755676576786756343 равно -80 978 314 018 755,25. Результат не является неправильным, но точность очень мала, чего не должно быть, поскольку для него установлено значение 50. Я пробовал ту же операцию с точно такими же значениями на веб-сайте, который позволял мне выполнять вычисления с большими числами, и это дало мне этот результат -80 978 314 018 755,259021173504356402067985275290755170372732462. Ниже приведен код, который я использовал.
#include
#include
#include

enum SBP_Operation {
OP_SUM,
OP_DIFFERENCE,
OP_PRODUCT,
OP_QUOTIENT
};

void RemoveRepeatitiveZeros(std::string& num) {
while (true) {
if (num.find('.') == std::string::npos) { break; };
if (num.back() != '0') { break; };
if (num.back() == '0' && num.find('.') + 1 == num.length() - 1) { break; };
num.pop_back();
};
};

std::string MathOpAr(const std::string& num1, const std::string& num2, int precision, SBP_Operation op) {
long double n1 = std::stold(num1);
long double n2 = std::stold(num2);
long double result = 0;
std::ostringstream out;
out.precision(precision);

switch (op) {
case OP_SUM: {
result = n1 + n2;
} break;
case OP_DIFFERENCE: {
result = n1 - n2;
} break;
case OP_PRODUCT: {
result = n1 * n2;
} break;
case OP_QUOTIENT: {
result = n1 / n2;
} break;
};

out

Подробнее здесь: https://stackoverflow.com/questions/793 ... ringstream
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»