Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Алгоритм и программа разложения степени числа по правилам арифметики вычетов





 

Алгоритм разложения степени числа

 

В Delphi имеется встроенная процедура возведения числа а в степень x y:=IntPower(a,x), содержащаяся в библиотеке Math. Недостаток данной процедуры, как ранее отмечено, состоит в переполнении формата результата процедуры y в оперативной памяти компьютера при относительно небольших значениях а и х.

Разработаем собственную процедуру разложения степени числа по пра­вилам арифметики вычетов, позволяющую исключить огромные результаты промежуточных вычислений.

Для упорядочивания разложения выражения b= aХ mod n по степеням числа х результат вычисления будем записывать в переменную с, значения которой на каждой итерации разложения i определяется следующей логикой вычислений:

i=1: b= a1 mod n → с = b ();

i=2: b= a2 mod n = (a*a) mod n = ((a mod n) * (a mod n)) mod n =(b*b) mod n

c = (c*b) mod n ();

i=3: b= a3 mod n = (a2*a) mod n = ((a2 mod n) * (a mod n)) mod n =(c*b) mod n

c = (c*b) mod n ();

i=x: ().

В виде алгоритма представленная последовательность итераций приве­дена на рисунке 3.3. Согласно алгоритмы, исходный код функции разложения степени числа по правилам арифметики вычетов выгладит следующим обра­зом:

Function aXmodN(a,x,n: integer): integer;

Var i,b,c: integer;

Begin

i:=0; b:= a mod n; c:=0;

While i<x do

Begin

i:=i+1;

If i=1 then c:=b else c:= (c*b) mod n;

End;

aXmodN:=c;

end;{aXmodN}

 

Рисунок 3.3 – Алгоритм разложения степени числа

 

Таким образом, программный код вида y:=IntPower(a,x)mod n можно заменить выражением y:= aXmodN(a,x,n). Для исследования воз­можностей и преимуществ разработанной функции по сравнению с использо­ванием встроенной процедурой Delphi y:=IntPower(a,x) напишем спе­циальное приложение.

 

3.3.2.2 Приложение для исследования вариантов разложения сте­пени числа

 

Рисунок 3.4 – Экранная форма приложения для исследования фунций y:=IntPower(a,x) и y:= aXmodN(a,x,n)

Рисунок 3.5 – Компоненты экранной формы приложения

 

 







Дата добавления: 2015-08-31; просмотров: 533. Нарушение авторских прав; Мы поможем в написании вашей работы!




Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...


Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...


Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...


Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...

Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...

Краткая психологическая характеристика возрастных периодов.Первый критический период развития ребенка — период новорожденности Психоаналитики говорят, что это первая травма, которую переживает ребенок, и она настолько сильна, что вся последую­щая жизнь проходит под знаком этой травмы...

РЕВМАТИЧЕСКИЕ БОЛЕЗНИ Ревматические болезни(или диффузные болезни соединительно ткани(ДБСТ))— это группа заболеваний, характеризующихся первичным системным поражением соединительной ткани в связи с нарушением иммунного гомеостаза...

Тема: Составление цепи питания Цель: расширить знания о биотических факторах среды. Оборудование:гербарные растения...

В эволюции растений и животных. Цель: выявить ароморфозы и идиоадаптации у растений Цель: выявить ароморфозы и идиоадаптации у растений. Оборудование: гербарные растения, чучела хордовых (рыб, земноводных, птиц, пресмыкающихся, млекопитающих), коллекции насекомых, влажные препараты паразитических червей, мох, хвощ, папоротник...

Типовые примеры и методы их решения. Пример 2.5.1. На вклад начисляются сложные проценты: а) ежегодно; б) ежеквартально; в) ежемесячно Пример 2.5.1. На вклад начисляются сложные проценты: а) ежегодно; б) ежеквартально; в) ежемесячно. Какова должна быть годовая номинальная процентная ставка...

Studopedia.info - Студопедия - 2014-2026 год . (0.008 сек.) русская версия | украинская версия