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

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

Примеры выполнения задания лабораторной работы. Пример 1. Составьте программу нахождения числа сочетаний из n элементов по m по формуле





 

Пример 1. Составьте программу нахождения числа сочетаний из n элементов по m по формуле

Решение. Для решения данной задачи составим процедуры Cnm и Fact (текст программы) (рис. 6.1).

На рис. 6.2 представлена схема алгоритма функции нахождения n!.

 

       
   
 

 

 


Рис. 6.1. Схема алгоритма головной программы Рис. 6.2. Схема алгоритма функции нахождения n!

 

Текст программы

 

program lr6_1_1;

{ Вычисление C из n по m =n! /(m! *(n-m)!)}

{ $APPTYPE CONSOLE }

Uses

SysUtils;

Var

m, n: integer;

function fact(const n: integer): int64;

{ Нахождение n! }

Var

i: integer;

p: longint;

Begin

p: =1;

for i: =1 to n do

p: = p * i;

fact: = p;

end;

Begin

clrscr;

write('n и m = ');

readln(n, m);

writeln('n= ', n, ' m= ', m, ' Cmn= ', fact(n) div (fact(m)*fact(n - m)): 6);

readln;

End.

 

Если нахождение n! оформить в виде подпрограммы-про-цедуры, то предыдущая программа могла бы быть следующей:

 

program lr6_1_2;

{ Вычисление C из n по m =n! /(m! *(n-m)!) }

{ $APPTYPE CONSOLE }

Uses

SysUtils;

Var

m, n: integer;

fn, fm, fn_m, Cnm: int64;

procedure fact(const n: integer; var p: int64);

{ Нахождение n! }

Var

i: integer;

Begin

p: =1;

for i: =1 to n do

p: = p * i;

end;

Begin

write('n и m = ');

readln(n, m);

fact(n, fn); { Обращение к процедуре Fact для нахождения }

fact(m, fm); { факториалов n, m, n-m }

fact(nm, fn_m);

Cnm: =fn div (fm*fn_m); { Нахождение числа сочетаний из n по m }

writeln('n= ', n, ' m= ', m, ' Cmn= ', Cnm: 6);

readln;

end.

 

Оформим вычисление искомой величины в виде функции Cmn, содержащей внутри себя описание функции вычисления факториала.

 

program lr6_1_3;

{ Вычисление C из n по m =n! /(m! *(n-m)!) }

{ $APPTYPE CONSOLE }

Uses

SysUtils;

Var

m, n: integer;

function Cmn (cons t m, n: integer): int64;

function fact(const n: integer): int64;

Var

i: integer;

p: int64;

Begin

p: =1;

for i: =1 to n do

p: = p * i;

fact: = p;

end;

Begin

Cmn: =fact(n) div (fact(m)*fact(n-m));

end;

Begin

write('m и n = ');

readln(m, n);

writeln('m= ', m, ' n= ', n, ' Cmn= ', Cmn (m, n): 6);

readln;

End.

Надо заметить, что приведенные примеры не очень удачны с точки зрения эффективности алгоритмов. Понятно, что трижды вычислять заново факториалы чисел n, m, n-m совсем не обязательно.

Рассмотрим следующий пример.

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

Обратите внимание на то, в качестве фактического параметра, передаваемого по значению, может быть выражение, в частности вызов функции.

 







Дата добавления: 2014-11-10; просмотров: 824. Нарушение авторских прав; Мы поможем в написании вашей работы!




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


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


Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...


Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Измерение следующих дефектов: ползун, выщербина, неравномерный прокат, равномерный прокат, кольцевая выработка, откол обода колеса, тонкий гребень, протёртость средней части оси Величину проката определяют с помощью вертикального движка 2 сухаря 3 шаблона 1 по кругу катания...

Неисправности автосцепки, с которыми запрещается постановка вагонов в поезд. Причины саморасцепов ЗАПРЕЩАЕТСЯ: постановка в поезда и следование в них вагонов, у которых автосцепное устройство имеет хотя бы одну из следующих неисправностей: - трещину в корпусе автосцепки, излом деталей механизма...

Понятие метода в психологии. Классификация методов психологии и их характеристика Метод – это путь, способ познания, посредством которого познается предмет науки (С...

ТРАНСПОРТНАЯ ИММОБИЛИЗАЦИЯ   Под транспортной иммобилизацией понимают мероприятия, направленные на обеспечение покоя в поврежденном участке тела и близлежащих к нему суставах на период перевозки пострадавшего в лечебное учреждение...

Кишечный шов (Ламбера, Альберта, Шмидена, Матешука) Кишечный шов– это способ соединения кишечной стенки. В основе кишечного шва лежит принцип футлярного строения кишечной стенки...

Принципы резекции желудка по типу Бильрот 1, Бильрот 2; операция Гофмейстера-Финстерера. Гастрэктомия Резекция желудка – удаление части желудка: а) дистальная – удаляют 2/3 желудка б) проксимальная – удаляют 95% желудка. Показания...

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