Мне нужен способ выполнения основных математических операций (таких как 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
Неправильные результаты точности с std::ostingstream ⇐ C++
Программы на C++. Форум разработчиков
-
Anonymous
1735998441
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
Подробнее здесь: [url]https://stackoverflow.com/questions/79328818/wrong-precision-results-with-stdostringstream[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия