bsuir.info
БГУИР: Дистанционное и заочное обучение
(файловый архив)
Вход (быстрый)
Регистрация
Категории каталога
Другое [197]
Бухучет [16]
ВМиМОвЭ [4]
ОДМиТА [13]
ОЛОБД [17]
ООПиП [67]
ОС [19]
ПСОД [47]
Форма входа
Поиск
Статистика

Онлайн всего: 1
Гостей: 1
Пользователей: 0
Файловый архив
Файлы » ИСиТвЭ » Другое

Контрольная по ОКП №1 Вариант 17
Подробности о скачивании 12.01.2011, 12:18
Содержание

1 Определение алгоритма......................................................................................3
2 Свойства алгоритма.............................................................................................3
3 Способы описания алгоритма.............................................................................4
4 Базовые структуры блок-схем............................................................................5
5 Структурированные блок схемы и их построение..........................................7
6 Линейные и разветвляющиеся структуры.........................................................9
7 Циклические структуры. Типы циклов.............................................................10
8 Предопределенные процессы. Рекурсия...........................................................11
Задача №1................................................................................................................12
Задача №2................................................................................................................16
Список используемых источников.......................................................................20

1 Определение алгоритма

Алгоритм - это конечная последовательность команд исполнителю для выполнения некоторой работы или решения задачи.
Создание алгоритма, пусть даже самого простого – процесс творческий. Он доступен исключительно живым существам, а долгое время считалось, что только человеку. Другое дело – реализация уже имеющегося алгоритма. Ее можно поручить субъекту или объекту, который не обязан вникать в существо дела, а возможно, и не способен его понять. Такой субъект или объект принять называть формальным исполнителем.
Каждый алгоритм создается в расчете на вполне конкретного исполнителя. Те действия, которые может совершить исполнитель, называются его допустимыми действиями. Совокупность допустимых действий образуют систему команд исполнителя. Алгоритм должен содержать только те действия, которые допустимы для данного исполнителя.

2 Свойства алгоритма

Разработать алгоритм решения задачи означает разбить задачу на последовательно выполняемые шаги, причем результаты выполнения предыдущих этапов могут использоваться при выполнении последующих. При этом должны быть четко указаны как содержание каждого шага, так и порядок выполнения шагов, т.к. компьютер – формальный исполнитель.
Свойства:
1. Понятность – каждая команда должна быть понятна исполнителю, т.е. входить в систему команд исполнителя.
2. Дискретность(прерывность, раздельность) – алгоритм должен представлять процесс решения задачи как последовательное выполнение простых (или ранее определенных шагов). Каждое действие, предусмотренное алгоритмом, исполняется только после того, как закончилось исполнение предыдущего.
3. Определенность(детерминированность) – каждое правило алгоритма должно быть четким, однозначным. Кроме того, в алгоритмах недопустимы также ситуации, когда после выполнения очередной команды алгоритма исполнителю неясно, какая из команд алгоритма должна выполняться на следующем шаге. Благодаря этому свойству выполнение алгоритма носит механический характер и не требует никаких дополнительных указаний или сведений о решаемой задаче.
4. Результативность. Смысл этого требования состоит в том, что при точном исполнении всех предписаний алгоритма процесс должен прекратиться за конечное число шагов и при этом должен получиться определённый результат. Вывод о том, что решения не существует - тоже результат.
5. Массовость – алгоритм должен решать любую задачу из того класса задач, для решения которых он разработан. При этом исходные данные могут выбираться из некоторой области, которая называется областью применимости алгоритма. Например, алгоритм решения квадратного уравнения должен решать любое квадратное уравнение.

3 Способы описания алгоритма

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

4 Базовые структуры блок-схем

Базовые алгоритмические структуры. Используя исходные элементы блок-схем можно собрать более крупные кирпичики, которые называют базовыми структурами. Базовые структуры (конструкции):
1. следование;
2. ветвление (полное и не полное);
3. повторение (цикл с предусловием или постусловием);
4. вход;
5. выход.
Каждая базовая структура имеет один вход и один выход. Схемы основных базовых алгоритмических структур:
Следование Повторение (Цикл )

Ветвление (полное)

Выбор (оператор switch)

5 Структурированные блок схемы и их построение

Блок-схема называется структурированной, если она построена на основе базисного множества базовых структур.
Для построения структурированных блок-схем была разработана специальная технология, которая называется пошаговой детализацией. Пошаговая детализация представляет собой процесс дробления задачи на модули, т.е. исходя из общей задачи, вычленяются подзадачи, устанавливаются логические связи между ними. После этого переходят к уточнению выделенных подзадач. Этот процесс детализации продолжается до уровня позволяющего достаточно легко реализовать подзадачу на выбранном языке программирования.
При пошаговой детализации используется принцип замещения, который состоит в замене любого функционального блока (прямоугольника) блок-схемы некоторой базовой структурой (следование, ветвление, повторение) из исходного базисного множества. Достоинство пошаговой детализации состоит в том, что она позволяет разработчику алгоритма упорядочить свои рассуждения.

Пример. Построить структурированную блок-схему алгоритма для вычисления функции

На первом шаге задачу представим в виде одного блока, в котором запишем кратко условие задачи.

На втором шаге функциональный блок преобразуем в развилку, где выделено вычисление Y при x<0.

На последнем шаге функциональный блок предыдущей схемы заменяем развилкой.

В итоге выполнения нескольких шагов мы получили структурированную блок-схему алгоритма решения задачи.

6 Линейные и разветвляющиеся структуры

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

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

7 Циклические структуры. Типы циклов.

Алгоритм циклической структуры – это алгоритм, в котором предусмотрено неоднократное выполнение одной и той же последовательности действий. На практике часто встречаются задачи, в которых одно или несколько действий бывает необходимо повторить несколько раз.
Многократное повторение последовательности действий называется циклом, а многократно повторяющиеся действия – телом цикла.
Изучение циклов демонстрирует главное преимущество компьютера перед человеком – выполнение большого числа действий за короткое время. Ведь даже весьма короткий циклический алгоритм, составить который не так уж долго, при исполнении может потребовать выполнения нескольких сотен действий, с которыми компьютер справится намного быстрее, чем человек.
Существует три формы циклов: цикл с параметром, цикл с предусловием, цикл с постусловием. Нетрудно заметить, что эти циклы взаимозаменяемы и обладают некоторыми отличиями.
1. в цикле с предусловием условие проверяется до тела цикла, в цикле с постусловием - после тела цикла;
2. в цикле с постусловием тело цикла выполняется хотя бы один раз, в цикле с предусловием тело цикла может не выполниться ни разу;
3. в цикле с предусловием проверяется условие продолжения цикла, в цикле с постусловием - условие выхода из цикла.
8 Предопределенные процессы. Рекурсия.

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

Пример прямой рекурсии:
int a()
{.....a().....}
Пример косвенной рекурсии:

a(){.....b().....}
b(){.....c().....}
c(){.....a().....} .
Предопределенный процесс — это символ, который отображает предопределенный процесс, состоящий из одной или нескольких операций или шагов программы, которые определены в другом месте (в подпрограмме, модуле). Изображается следующим образом:

Задача № 1

Найти значение максимального элемента среди элементов, кратных k и расположенных до первого отрицательного элемента.

Решение задачи на языке программирования C:

#include <stdio.h>
#include <stdlib.h>
main(){
int i,j,k,maxi=0,z=0,a[50],maxx=0;
printf("Введите значение kратности k=");scanf("%d",&k);
for (i=0;i<50;i=i+1){
a[i]=(rand()%100+1)-20;
printf("a[%d]=%d\n",i,a[i]);}
printf("\nЭлементы кратные k=%d\n",k);
for (i=k;i<50;i=i+k){
printf("a[%d]=%d\n",i,a[i]);
if (a[i]<0){
if (i==k){
printf("Положительные элементы отсутствовали!!!\n");
maxi=i;
maxx=a[i];}
printf("Максимальный элемент является a[%d]=%d\n",maxi,maxx);
z=z+1;break;}
if (maxx<a[i]){
maxi=i;maxx=a[i];}}
if (z==0){
printf("Отрицательный элемент отсутствовал!!!\n");
printf("Максимальный элемент является a[%d]=%d\n",maxi,maxx);}}

Блок-схема решения задачи:

Выполнение программы:

Начало
Инициализация переменных
int i,j,k,maxi=0,z=0,a[50],maxx=0;
Ввод значения кратности
printf("Введите значение kратности k=");scanf("%d",&k);
Заполняем массив случайными числами по средством цикла
for (i=0;i<50;i=i+1)
{a[i]=(rand()%100+1)-20;
Вывод заполненного элемента на экран
printf("a[%d]=%d\n",i,a[i]);}
Вывод сообщения “Элементы кратные k=” и самого значения k
printf("\nЭлементы кратные k=%d\n",k);
Вывод элементов массива кратного k
for (i=k;i<50;i=i+k){
printf("a[%d]=%d\n",i,a[i]);
Проверка элемента кратного k. Является ли он отрицательным числом.
if (a[i]<0){
если элемент кратный k является отрицательным числом, то идет проверка является ли этот элемент первым(единственным) проверяемым элементом.
if (i==k){
Если элемент является первым, то выводиться сообщение и максимальному элементу присваивается данное значение и порядковый номер элемента в массиве.
printf("Положительные элементы отсутствовали!!!\n");
maxi=i;maxx=a[i];}
Продолжается выполнение первого условия с отрицательностью элемента. Выводиться сообщение о максимальном элементе. Z увеличивается на единицу. Прерывается выполнение цикла.
printf("Максимальный элемент является a[%d]=%d\n",maxi,maxx);
z=z+1;
break;}
Идет проверка элемента. Является ли текущий элемент больше максимального. Если да, то идет присвоение нового значения. Если нет, то ничего не происходит
if (maxx<a[i]){
maxi=i;maxx=a[i];} }
Идет проверка. Выполнялось ли хоть раз условие отрицательного элемента. Если встречался отрицательный элемент в искомой нами области, то ничего не происходит, если же нет, то выводиться соответствующее сообщение и выводиться максимальный элемент.
if (z==0){
printf("Отрицательный элемент отсутствовал!!!\n");
printf("Максимальный элемент является a[%d]=%d\n",maxi,maxx);}}
Конец
Задача № 2

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

Решение задачи на языке программирования C:

#include <stdio.h>
#include <stdlib.h>
main(){
int z,i,j,a[4][10],k;z=0;
for (i=0;i<4;i++){
for (j=0;j<10;j++){
a[i][j]=(rand() % 58+1)-50;printf("a[%d][%d]=%d ",i,j,a[i][j]);}
printf("\n");}printf("\n");printf("Ответ:\n");k=0;
for (j=0;j<10;j++){
for (i=1;i<4;i++){
if (a[i][j]<a[i-1][j]){
z=z+1;
if (z==3){
printf("Столбец %d\n",j);k++;
for (i=0;i<4;i++){
if (a[i][j]<0){
a[i][j]=abs(a[i][j]);}}}}}z=0;}
if (k==0){
printf("Нет таких столбцов!!\n");}
for (i=0;i<4;i++){
for (j=0;j<10;j++){
printf("a[%d][%d]=%d ",i,j,a[i][j]);}
printf("\n");} printf("\n");}
Блок-схема решения задачи:

Выполнение программы:

Начало
Инициализация переменных
int z,i,j,a[4][10],k;z=0;
Заполнение двухмерного массива случайным набором чисел от -50 до 8. Вывод полученного массива на экран. Вывод сообщения "Ответ:".
for (i=0;i<4;i++){
for (j=0;j<10;j++){
a[i][j]=(rand() % 58+1)-50;printf("a[%d][%d]=%d ",i,j,a[i][j]);}
printf("\n");}printf("\n");printf("Ответ:\n");
Поиск столбцов с упорядоченными элементами по убыванию. Проверяем является ли текущий элемент меньше прошлого. Если да, то z=z+1 для того чтобы проверить. Все ли следующие элементы были меньше предыдущих.
k=0;
for (j=0;j<10;j++){
for (i=1;i<4;i++){
if (a[i][j]<a[i-1][j]){
z=z+1;
Все ли следующие элементы были меньше предыдущих. Если да, то выводим наш столбец. Если нет,
if (z==3){
printf("Столбец %d\n",j);k++;
Заменяем элементы на положительные с помощью цикла, если элементы отрицательный.
for (i=0;i<4;i++){
if (a[i][j]<0){
a[i][j]=abs(a[i][j]);}}}}}
Проверяем был ли хоть один такой столбец. Если да, то выводим сообщение.
if (k==0){
printf("Нет таких столбцов!!\n");}
Выводим массив с положительными элементами в искомых столбцах, если такие были.
for (i=0;i<4;i++){
for (j=0;j<10;j++){
printf("a[%d][%d]=%d ",i,j,a[i][j]);}
printf("\n");} printf("\n");}
Конец.
Список используемых источников
1 Мытник Н.П. «Основы конструирования программ» / Мытник Н.П. Минск: БГУИР, 2010.
2 Крупник А. Б. «Изучаем Cи» / Крупник А. Б. Минск, 2001 — 233 с.

Категория: Другое | Добавил: iribnix
Просмотров: 2291 | Загрузок: 42
Всего комментариев: 0
Добавлять комментарии могут только зарегистрированные пользователи.
[ Регистрация | Вход ]