Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.84/50: Рейтинг темы: голосов - 50, средняя оценка - 4.84
1 / 1 / 1
Регистрация: 13.12.2010
Сообщений: 68

Подскажите алгоритм возведения числа в степень по модулю

14.05.2012, 17:38. Показов 10114. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите пожалуйста самый простой, на ваш взгяд, алгоритм возведения числа в степень по мудулю
Число a и степень t BigInteger. Можно даже с кодом) Буду очень признателен.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.05.2012, 17:38
Ответы с готовыми решениями:

Алгоритм быстрого возведения в степень по модулю
Народ помогите начинающему как реализовать алгоритм быстрого возведения в степень по модулю C#. Если можно скинте пример плиз.

Алгоритм возведения в степень по модулю
Доброго времени суток! Пишу алгоритм для декодирования шифра RSA. В этом алгоритме требуется возводить очень большое число в очень большую...

Алгоритм возведения в 4-ю степень введённого числа
Между командами ввода и вывода впишите в алгоритм несколько команд присваивания, в результате чего должен получиться алгоритм возведения в...

8
0 / 0 / 0
Регистрация: 11.05.2012
Сообщений: 5
14.05.2012, 19:46
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
string buf;
            double a;
 
            Console.WriteLine("Введите число:");
            buf = Console.ReadLine();
            a = Double.Parse(buf);
            double t;
 
            Console.WriteLine("Введите степень:");
            buf = Console.ReadLine();
            t = Double.Parse(buf);
 
            double p = a;
            {
                for (int i = 1; i < t; ++i) ;
                p = p * a;
            }
            Console.WriteLine("p= " + p);
            Console.ReadKey();
0
 Аватар для phoenfix
39 / 39 / 8
Регистрация: 30.04.2012
Сообщений: 128
14.05.2012, 19:54
Math.Exp(j * Math.Log(i)) - тоже способ, где i, j естественно переменные и i степень
0
1 / 1 / 1
Регистрация: 13.12.2010
Сообщений: 68
14.05.2012, 20:20  [ТС]
Не думаю что мне действительно следует возводить в лоб, а потом вычислять остаток.

Например нужно вычислить (894549595024559059045^7845543244545) mod 3
Насколько я знаю, нужно понижать степень пользуясь формулами типа ( a * b ) mod c = ( ( a mod c ) * ( b mod c ) ) mod c . Но я не совсем уверен в достоверности этой формулы и кроме того возникает вопрос, если она верна, как это реализовать...
0
 Аватар для Lasur
267 / 257 / 43
Регистрация: 18.03.2012
Сообщений: 506
14.05.2012, 20:27
Алгоритм Монтгомери
В случае быстрого возведения в квадрат:
Схема Горнера

Не так давно писал свою реализация BigInteger, в том числе с этой функцией. Найду - выложу код.
1
 Аватар для kuroiryuu
328 / 312 / 68
Регистрация: 05.11.2009
Сообщений: 712
14.05.2012, 20:28
Цитата Сообщение от Nantaur Посмотреть сообщение
Например нужно вычислить (894549595024559059045^7845543244545) mod 3
Насколько я знаю, нужно понижать степень пользуясь формулами типа ( a * b ) mod c = ( ( a mod c ) * ( b mod c ) ) mod c . Но я не совсем уверен в достоверности этой формулы и кроме того возникает вопрос, если она верна, как это реализовать...
Для этого используется логарифмическое возведение в степень числа, "погуглите"...
даже вроде исходники есть на сишке
1
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
15.05.2012, 06:58
У класса BigInteger есть метод, делающий точно, что вам нужно - ModPow
1
1 / 1 / 1
Регистрация: 13.12.2010
Сообщений: 68
15.05.2012, 07:12  [ТС]
turbanoff, где же вы раньше были)))

Цитата Сообщение от kuroiryuu Посмотреть сообщение
Для этого используется логарифмическое возведение в степень числа, "погуглите"...
даже вроде исходники есть на сишке
Спасибо, действительно полезная вещь оказалась))

Использовал в тесте Миллера-Рабина на определение простого числа, быстродействие правда оставляет желать лучшего)) Но может быть это косяки моей реализации. Думаю, лучше всетаки ModPow использовать))

Lasur, спасибо за информацию, от кода, если найдете, не откажусь)
0
 Аватар для Lasur
267 / 257 / 43
Регистрация: 18.03.2012
Сообщений: 506
15.05.2012, 18:42
Код моего BigInteger под названием LargeNumber. Нужная функция - PowMod(LargeNumber pow, LargeNumber mod). Писалось давно неопытным мной, может быть ускорено, хотя работает довльно быстро. Еще из минусов - создание чисел парсингом только с Hex или Binary строк. Пишите, если будут ошибки.
LargeNumber.rar
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.05.2012, 18:42
Помогаю со студенческими работами здесь

Как работает алгоритм возведения числа a в степень n ?
Добрый день! Собственно, вопрос не по коду, а по алгоритму Почему после выполнения этой программы в res содержится значение an ? Как оно...

Написал программу для возведения числа X в степень N по модулю P. Как можно уменьшить макс. время работы программы?
#include &lt;iostream&gt; using namespace std; int main() { int c = 1; int x, n, p; cin &gt;&gt; x &gt;&gt; n &gt;&gt; p; for (int i = 0; i &lt;...

Напишите алгоритм и программу возведения числа в четвертую степень за две операции
Помогите пожалуйста) Напишите алгоритм и программу возведения числа в четвертую степень за две операции.

Алгоритм Возведения в Степень
1) Подробная постановка задачи: Разработать библиотеку для работы с большими числами (+, -, ==, ^). Возведение в степень должно иметь...

Алгоритм для быстрого возведения в степень
Всем привет, помогите написать алгоритм для возведения в степень дак чтоб для возведения в 15 степень требуется 6 операций умножения, а для...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru