Я ищу способ надежного вычисления больших биномиальных коэффициентов в C++. Моя текущая реализация может обрабатывать числа примерно до n=60, но после этого f * (n - i) превышает предел long long. Я хочу дойти до n=100, после чего результирующие биномиальные коэффициенты могут достигать 10E29.
Мне бы хотелось, чтобы точность результата была такой же высокой. насколько это возможно, но было бы нормально передать менее точный результат, если биномиальные коэффициенты очень велики (например, 15 значащих цифр). Но я не знаю, как реализовать это с каким-либо фиксированным типом возвращаемого значения — long long или другим.
long long comb(long long n, long long r)
{
long long f = 1;
for(auto i = 0; i < r; i++){
f = (f * (n - i)) / (i + 1);
}
return f ;
}
Подробнее здесь: https://stackoverflow.com/questions/787 ... ients-in-c
Стабильный расчет больших биномиальных коэффициентов в C++ ⇐ C++
Программы на C++. Форум разработчиков
-
Anonymous
1720059814
Anonymous
Я ищу способ надежного вычисления больших биномиальных коэффициентов в C++. Моя текущая реализация может обрабатывать числа примерно до n=60, но после этого f * (n - i) превышает предел long long. Я хочу дойти до n=100, после чего результирующие биномиальные коэффициенты могут достигать 10E29.
Мне бы хотелось, чтобы точность результата была такой же высокой. насколько это возможно, но было бы нормально передать менее точный результат, если биномиальные коэффициенты очень велики (например, 15 значащих цифр). Но я не знаю, как реализовать это с каким-либо фиксированным типом возвращаемого значения — long long или другим.
long long comb(long long n, long long r)
{
long long f = 1;
for(auto i = 0; i < r; i++){
f = (f * (n - i)) / (i + 1);
}
return f ;
}
Подробнее здесь: [url]https://stackoverflow.com/questions/78704800/stable-calculation-of-large-binomial-coefficients-in-c[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия