Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Методические указания к самостоятельной работе.doc
Скачиваний:
21
Добавлен:
10.05.2015
Размер:
189.95 Кб
Скачать

Тема 4.1Вычислительная сложность алгоритмов

Общая трудоемкость 9 час, в том числе аудиторная работа 2 часа, самостоятельная работа 7 часов .

В ходе аудиторных студенты знакомятся с понятием вычислительной сложности алгоритмов, ее видами и способами расчета. В ходе самостоятельной работы студенты учатся вычислять временную и емкостную вычислительную сложность в соответствии с равномерным и логарифмическим весовым критериями [1].

Задачи для самоконтроля по теме 4:1

Определить временную и емкостную сложность следующего алгоритма при равномерном и логарифмическом весовых критериях:

  1. Алгоритм метода поиска перебором в квадратной матрице.

  2. Алгоритм метода бинарного поиска в квадратной матрице.

  3. Алгоритм метода сортировки вставками для одномерного массива.

  4. Алгоритм метода сортировки Хоара для одномерного массива.

  5. Алгоритм метода сортировки слиянием для одномерного массива.

  6. Алгоритм метода сортировки расческой для одномерного массива.

  7. Алгоритм метода сортировки Шелла для одномерного массива.

  8. Алгоритм построения таблицы истинности логической функции трёх переменных (на примере конкретной функции).

  9. Алгоритм построения таблицы значений функции (на примере конкретной функции).

  10. Алгоритм поиска минимального элемента в матрице.

  11. Алгоритм вычисления суммы элементов главной диагонали матрицы.

  12. Алгоритм суммирования элементов квадратной матрицы, расположенных в нечётных строках.

  13. Алгоритм умножения двух матриц.

  14. Алгоритм вычисления суммы элементов матрицы, выделенных на рисунке символом х (m = n):

  15. Алгоритм вычисления суммы элементов матрицы, выделенных на рисунке символом х (m = n):

  16. Алгоритм поворота квадратной матрицы против часовой стрелки на 90 градусов.

  17. Алгоритм нахождения одного из седловых элементов квадратной матрицы (наибольший в строке и наименьший в столбце).

  18. Алгоритм проверки, является ли матрица магическим квадратом (суммы элементов всех строк и столбцов одинаковы).

  19. Алгоритм нахождения суммы последних элементов каждой строки и каждого столбца квадратной матрицы.

  20. Алгоритм перестановки левой и правой половин квадратной матрицы (размер n матрицы является четным числом).

Тема 3.4. Машины Тьюринга.

Общая трудоемкость 7 часов в том числе аудиторные занятия 2 часа, самостоятельная работа 5 часов.

В ходе аудиторных занятий студенты изучают понятие машины Тьюринга, способы построения машин Тьюринга для решения алгоритмических задач, в ходе самостоятельной работы студенты учатся составлять программу машины Тьюринга в заданном алфавите и показsdfnm ее работоспособность на примерах. В ходе самостоятельной работы студенты тренируются в составлении программ машины Тьюринга [1], Дополнительные главы. Глава 1.

Задачи для самоконтроля по теме 2.5:

Составить программу машины Тьюринга в заданном алфавите и показать ее работоспособность на примере

1 A={a,b,c}. Приписать слева к слову P символ b (P bP).

2 A={a,b,c}. Приписать справа к слову P символы bc (P Pbc).

3 A={a,b,c}. Заменить на a каждый второй символ в слове P.

4 A={a,b,c}. Оставить в слове P только первый символ (пустое слово не

менять).

5 A={a,b,c}. Оставить в слове P только последний символ (пустое слово не

менять).

6 A={a,b,c}. Определить, является ли P словом ab. Ответ (выходное слово):

слово ab, если является, или пустое слово иначе.

7 A={a,b,c}. Определить, входит ли в слово P символ a. Ответ: слово из

одного символа a (да, входит) или пустое слово (нет).

8 A={a,b,c}. Если в слово P не входит символ a, то заменить в P все символы

b на с, иначе в качестве ответа выдать слово из одного символа a.

9 A={a,b,0,1}. Определить, является ли слово P идентификатором (непустым

словом, начинающимся с буквы). Ответ: слово a (да) или пустое слово (нет).

10 A={a,b,0,1}. Определить, является ли слово P записью числа в двоичной

системе счисления (непустым словом, состоящем только из цифр 0 и 1). Ответ:

слово 1 (да) или слово 0.

11 A={0,1}. Считая непустое слово P записью двоичного числа, удалить из

него незначащие нули, если такие есть.

12 A={0,1}. Для непустого слова P определить, является ли оно записью

степени двойки (1, 2, 4, 8, …) в двоичной системе счисления. Ответ: слово 1

(является) или слово 0.

13 A={0,1,2,3}. Считая непустое слово P записью числа в четверичной

системе счисления, определить, является оно чётным числом или нет. Ответ: 1

(да) или 0.

14 A={0,1}. Считая непустое слово P записью числа в двоичной системе, полу-

чить двоичное число, равное учетверенному числу P (например: 101 → 10100).

15 A={0,1}. Считая непустое слово P записью числа в двоичной системе,

получить двоичное число, равное неполному частному от деления числа P на 2

(например: 1011 → 101).

16 A={a,b,c}. Если P – слово чётной длины (0, 2, 4, …), то выдать ответ a,

иначе – пустое слово.

17 A={0,1,2}. Считая непустое слово P записью числа в троичной системе

счисления, определить, является оно чётным числом или нет. Ответ: 1 (да) или 0.

(Замечание: в чётном троичном числе должно быть чётное количество цифр )

18 A={a,b,c}. Пусть P имеет нечётную длину. Оставить в P только средний

символ.

19 A={a,b,c}. Если слово P имеет чётную длину, то оставить в нём только

левую половину.

20 A={a,b,c}. Приписать слева к непустому слову P его первый символ.

21 A={a,b}. Для непустого слова P определить, входит ли в него ещё раз его

первый символ. Ответ: a (да) или пустое слово.

22 A={a,b}. В непустом слове P поменять местами его первый и последний

символы.

23 A={a,b}. Определить, является P палиндромом (перевёртышем, симмет-

ричным словом) или нет. Ответ: a (да) или пустое слово.

24 A={a,b}. Заменить в P каждое вхождение a на bb.

25 A={a,b,c}. Заменить в P каждое вхождение ab на c.

26 A={a,b}. Удвоить слово P (например: abb abbabb).

27 A={a,b}. Удвоить каждый символ слова P (например: bab bbaabb).

28 A={a,b}. Перевернуть слово P (например: abb bba).

29 A={0,1}. Считая непустое слово P записью двоичного числа, получить это

же число, но в четверичной системе. (Замечание: учесть, что в двоичном числе

может быть нечётное количество цифр.)

30 A={0,1,2,3}. Считая непустое слово P записью числа в четверичной

системе счисления, получить запись этого числа в двоичной системе.

31 A={0,1,2}. Считая непустое слово P записью положительного числа в

троичной системе счисления, уменьшить это число на __

СПИСОК РЕКОМЕНДУЕМОЙ ЛИТЕРАТУРЫ ПО РАЗДЕЛУ 2

1. Новиков, Ф. А. Дискретная математика для программистов : учеб. пособие для вузов / Ф. А. Новиков .— 3-е изд. — М. [и др.] : Питер, 2009 .— 384 с. : ил. — (Учебник для вузов) .— Библиогр.: с. 368-369 .— Предм. указ.: с. 370-383 .— ISBN 978-5-91180-759-7 ((в пер.))

2. Лихтарников Л. M., Сукачева Т. Г. Математическая логика. Курс лекций. Задачник-практикум и решения. Серия "Учебники для вузов. Специальная литература" / Оформление обложки С. Л. Шапиро, А. А. Олексенко. — СПб.: Издательство "Лань", 1999. — 288 с.

3. Ахо, А. Построение и анализ вычислительных алгоритмов / А.Ахо,Д.Хопкрофт,Дж.Ульман;Пер.с англ.А.О.Слисенко;Под ред.Ю.В.Матиясевича .— М. : Мир, 1979 .— 536с. — Библиогр.в конце кн

4. Колмогоров А.Н., Драгалин А.Г. Математическая логика. Серия "Классический университетский учебник". Изд.3, стереот.2006. Твердый переплет. 240 с. ISBN 5-484-00520-5