Применение рекурсии в алгоритмах с возвратом. Файловый тип. Ввод/вывод

Цена:
19 руб.

Состав работы

material.view.file_icon
material.view.file_icon bestref-95796.rtf
Работа представляет собой zip архив с файлами (распаковать онлайн), которые открываются в программах:
  • Microsoft Word

Описание

Есть широкий спектр алгоритмов когда вычисления идут не по фиксированным правилам, а методом проб и ошибок. Примером таких алгоритмов могут служить алгоритм игры чет-нечет; алгоритм поиска пути в лабиринте в задаче об Ариадне и Тезее. Теперь рассмотрим применение рекурсии для решения таких задач.
Применение рекурсии рассматривается на примере задачи обхода шахматной доски ходом коня. Наряду с демонстрацией применения рекурсии еще раз демонcтрируется пошаговая, структурная разработка программы.
procedure попытка следующего хода;
begin
repeat
if ход приемлем? then
begin
if доска не заполнена? then
begin
if неудача? then стирание предыдущего хода;
end
end
until (ход был удачным?) or (нет других возможных ходов)
end.
В итоге выписывается полный текст программы на Pascal.
program ChessHorse;
const Dim = 5;
PathLen = Dim*Dim;
var Field :Array[1..Dim,1..Dim] of integer; { h[x, y]=i => на клетку
(x, y) конь попал после i-того хода }
n :integer; { Текущая длина пути }
x, y :integer;
function TryMove (i, j :integer) :Boolean;
begin
if n>PathLen then TryMove := true { Путь найден }
else
begin
TryMove := false;
if (i>=1) AND (i<=Dim) AND (j>=1) AND (j<=Dim) AND (Field[i, j]=0) then
begin
Field[i, j] := n;
n := n+1;
if TryMove(i+1, j+2)=true then TryMove := true
else if TryMove(i+1, j-2)=true then TryMove := true
else if TryMove(i-1, j+2)=true then TryMove := true
else if TryMove(i-1, j-2)=true then TryMove := true
else if TryMove(i+2, j+1)=true then TryMove := true
else if TryMove(i+2, j-1)=true then TryMove := true
else if TryMove(i-2, j+1)=true then TryMove := true
else if TryMove(i-2, j-1)=true then TryMove := true;
Field[i, j] := 0;
n := n-1;
end;
end;
end;
Begin
for x:=1 to Dim do
for y:=1 to Dim do
Field[x, y]:=0;
WriteLn ('Поле ', Dim, 'x', Dim);
WriteLn ('Введите координаты коня.');
Write ('X='); ReadLn (x);
Write ('Y='); ReadLn (y);
if (x<1) OR (x>Dim) OR (y<1) OR (y>Dim) then
WriteLn ('Неправильный ответ. System halted...');
else
begin
n := 1;
WriteLn ('Поиск путей длины ', PathLen, ' ...');
case TryMove (x, y) of
true: WriteLn ('Нашел путь :-)');
false: WriteLn ('Нет путей :-(');
end;
end;
End.
Файловый тип. Ввод/вывод.
Все рассмотренные ранее типы данных обладали одним общим свойством - число их компонентов конечно и заранее фиксировано. Однако, существует достаточно широкий класс задач, когда количество компонент данных заранее не известно. Пример - задача кодирования текста поступающего на вход в реальном времени, ввод текста, длина которого заранее не известна и т.п.
В Pascal существует тип данных, множество элементов которого есть последовательности однотипных элементов, длина этих последовательностей не фиксируется заранее. Важной характеристикой этого типа, называемого файловым, является то, что доступ к его компонентам строго последовательный. Это означает, чтобы получить доступ к i-му компоненту, необходимо пройти i-1-ый.
Файловый тип - это единственный тип, обладающий тем свойством, что данные этого типа могут иметь время жизни более времени выполнения программы ! Поэтому этот тип часто используют, чтобы сохранить результаты работы программы для последующей обработки; либо ввести данные извне. Примеры файлового типа, с которыми мы уже много раз встречались много раз - input и output.
Ввод/вывод данных
Функции преобразования строк Ввод данных Вывод строки Вывод числовых данных Логические переменные Логические операции Таблицы истинности Условный оператор IF Вычисление функции IF THEN Составной оператор CASE OF Циклические алгоритмы FOR Вычисление сумм и произведений Вывод алфавита в обратном порядке Поиск максимального положительного числа из Memo Break, Continue Безусловной переход Поиск частного Случайные числа Символьный тип Структурные типы данных
User Lokard : 21 мая 2013
5 руб.
Управление вводом-выводом
Одной из главных функций ОС является управление всеми устройствами ввода-вывода компьютера. ОС должна передавать устройствам команды, перехватывать прерывания и обрабатывать ошибки; она также должна обеспечивать интерфейс между устройствами и остальной частью системы. В целях развития интерфейс должен быть одинаковым для всех типов устройств (независимость от устройств). Физическая организация устройств ввода-вывода Устройства ввода-вывода делятся на два типа: блок-ориентированные устройства и б
User OstVER : 10 ноября 2012
5 руб.
Средства ввода-вывода в Си++
Введение. 2 Общие положения. 3 Потоковый ввод-вывод 9 Форматный ввод-вывод. 13 Форматный ввод из входного потока. 15 Литература 17 Введение. В стандарте языка Си отсутствуют средства ввода-вывода. Все операции ввода-вывода реализуются с помощью функций, находящихся в библиотеке языка Си, поставляемой в составе конкретной системы программирования Си. Во время работы с файлами данные могут передаваться или в своем внутреннем двоичном представлении или в текстовом формате, то есть в бол
User Lokard : 6 октября 2013
10 руб.
Ассемблер. ВВОД-ВЫВОД ЧИСЕЛ
В процессе выполнения работы решается практически важная задача вывода чисел на экран и их ввода с клавиатуры. Данная задача решается в следующей последовательности. Во-первых, рассматривается вывод на экран двоичного числа в виде последовательности единиц и нулей. Во-вторых, решается задача вывода на экран шестнадцатеричных чисел. В-третьих, рассматривается ввод шестнадцатеричных чисел с клавиатуры. В ходе работы производится знакомство с очень важными понятиями флагов состояния, стека и пр
User a-cool-a : 4 мая 2012
100 руб.
Адресное пространство. Подсистемы ввода-вывода
Процессоры Типы процессоров: 1. с регистрами общего назначения (РОН); 2. аккумуляторные; 3. стековые. Процессоры с РОН Любой регистр как операнд может участвовать в любой команде. Работа с операндами осуществляется только через регистры. Среди всех регистров выделяются два: SP - указатель стека PC - счетчик команд Нет команд push и pop, всегда используется mov: mov (SP)+,R0 вместо pop R0 mov R0,-(SP) вместо push R0 Вместо непосредстве
User alfFRED : 3 октября 2013
10 руб.
Организация ввода-вывода. Обработка массивов. Структурированные данные
СОДЕРЖАНИЕ Введение 1. ОРГАНИЗАЦИЯ ВВОДА-ВЫВОДА 1.1 Процедуры ввода 1.2 Процедуры вывода 1.3 Бесформатный вывод 1.4 Форматный вывод 1.5 Описание одномерных массивов 1.6 Ввод – вывод одномерных массивов 1.7 Описание двумерных массивов 1.8 Ввод – вывод двумерных массивов 2. ОБРАБОТКА МАССИВОВ. СТРУКТУРИРОВАННЫЕ ДАННЫЕ 2.1 Строки. Описание строки 2.2 Операции над строками 2.3 Процедуры и функции обработки строк 2.4 Комбинированный тип данных - записи. Описание записей 2.4.1 Записи с
User Elfa254 : 8 октября 2013
10 руб.
Лабораторная работа № 1 «Порты ввода/вывода» Вариант №3
Цель работы: изучение простейших команд языка С, портов ввода/вывода и отладка прикладных программ для микроконтроллера AVR семейства MEGA с помощью персонального компьютера и программного пакета Atmel Studio.
User antoniopim231111 : 27 февраля 2023
800 руб.
Системы ввода и вывода данных
Введение 3 Периферийные устройства ввода информации 3 Клавиатура 3 Манипуляторы 4 Мышь. 4 Джойстик 5 Трекбол. 5 Сенсорные устройства ввода 6 Световое перо. 6 Дигитайзер (графический планшет). 6 Сканеры 6 Цифровая видеокамера 7 Микрофон 8 Периферийные устройства вывода информации 8 Монитор 8 Принтеры 9 Плоттеры 10 Наушники или головные телефоны 10 Колонки, 10 Видеокамера 10 Заключение 11 Список использованной литературы 11 Персональный компьютер (ПК) – это не один электронный аппарат, а небольшой
User Aronitue9 : 12 мая 2012
20 руб.
ММА/ИДО Иностранный язык в профессиональной сфере (ЛТМ) Тест 20 из 20 баллов 2024 год
ММА/ИДО Иностранный язык в профессиональной сфере (ЛТМ) Тест 20 из 20 баллов 2024 год Московская международная академия Институт дистанционного образования Тест оценка ОТЛИЧНО 2024 год Ответы на 20 вопросов Результат – 100 баллов С вопросами вы можете ознакомиться до покупки ВОПРОСЫ: 1. We have … to an agreement 2. Our senses are … a great role in non-verbal communication 3. Saving time at business communication leads to … results in work 4. Conducting negotiations with foreigners we shoul
User mosintacd : 28 июня 2024
150 руб.
promo
Задание №2. Методы управления образовательными учреждениями
Практическое задание 2 Задание 1. Опишите по одному примеру использования каждого из методов управления в Вашей профессиональной деятельности. Задание 2. Приняв на работу нового сотрудника, Вы надеялись на более эффективную работу, но в результате разочарованы, так как он не соответствует одному из важнейших качеств менеджера - самодисциплине. Он не обязателен, не собран, не умеет отказывать и т.д.. Но, тем не менее, он отличный профессионал в своей деятельности. Какими методами управления Вы во
User studypro : 13 октября 2016
200 руб.
Особенности бюджетного финансирования
Содержание: Введение Теоретические основы бюджетного финансирования Понятие и сущность бюджетного финансирования Характеристика основных форм бюджетного финансирования Анализ бюджетного финансирования образования Понятие и источники бюджетного финансирования образования Проблемы бюджетного финансирования образования Основные направления совершенствования бюджетного финансирования образования Заключение Список использованный литературы Цель курсовой работы – исследовать особенности бюджетного фин
User Aronitue9 : 24 августа 2012
20 руб.
Программирование (часть 1-я). Зачёт. Билет №2
ЗАЧЕТ по дисциплине “Программирование (часть 1)” Билет 2 Определить значение переменной y после работы следующего фрагмента программы: a = 3; b = 2 * a – 10; x = 0; y = 2 * b + a; if ( b > y ) or ( 2 * b < y + a ) ) then begin x = b – y; y = x + 4 end; if ( a + b < 0 ) and ( y + x > 2 ) ) then begin x = x + y; y = x – 2 end;
User sibsutisru : 3 сентября 2021
200 руб.
Программирование (часть 1-я). Зачёт. Билет №2
up Наверх