По разработанным алгоритмам составить программы.

Лабораторная работа №1

Тема: Исследование временных характеристик алгоритмов.

Цель работы: Развитие умений и навыков теоретической и практической оценки временных характеристик алгоритмов.

Выполнение работы

Вариант 1.

 

Алгоритм линейного поиска. Вход: последовательность n чисел A=<a1,…,an> и число v. Выход: индекс i, для которого v=A[i] или NIL, если v не принадлежит А.

 

Использовать последовательный просмотр при поиске v. Оценить сколько сравнений потребуется алгоритму, если искомым может быть любой элемент массива А (с одинаковой вероятностью). Каково время работы в среднем и в худшем случае? Выразить это время -обозначением. При поиске в отсортированном массиве можно сначала сравнивать искомый элемент со средним элементом массива и, узнав в какой из полученных частей массива находится искомый, продолжить поиск рекурсивно (двоичный поиск).

Написать программу двоичного поиска, учтя время на сортировку, с рекурсией. Определить её .

Сравнить временные характеристики алгоритмов:

· линейного поиска,

· сортировки с двоичным поиском, представленными циклами,

· сортировки с двоичным поиском, представленными рекурсией.

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

 

Составим линейный алгоритм поиска

алг

нач

конст цел n:=4

цел i,v,j

целтаб A[1:n]

нц для i от 1 до n //вводим последовательность чисел

ввод A[i]

кц

ввод v // вводим с клавиатуры значение v

j:=0

нц для i от 1 до n // проверяем каждый элемент на совпадение с v

если A[i]=v то вывод i // если элемент равен v, то выводим его номер

иначе j:=j+1 // если нет, то увеличиваем счетчик элементом отличных от v

Все

кц

если j=n то вывод "NIL"

Все

кон

По разработанным алгоритмам составить программы.

Составим программу линейного поиска на языке С++

#include <iostream>

using namespace std;

int main()

{

int i,j=0,v;

const int n=100;

int A[n];

for (i=0; i<n; i++)

A[i]=rand()%10;

cin >> v;

for (i=0; i<n; i++)

if (A[i]==v) cout << i+1

else j++;

if (j==n) cout<<"NIL";

return 0;

}

Асимптотическая сложность алгоритма – O(n). Для списка из n элементов лучшим случаем будет тот, при котором искомое значение равно первому элементу списка и требуется только одно сравнение. Худший случай будет тогда, когда значения в списке нет (или оно находится в самом конце списка), в случае чего необходимо n сравнений.

Если искомое значение входит в список k раз и все вхождения равновероятны, то ожидаемое число сравнений

Например, если искомое значение встречается в списке один раз, и все вхождения равновероятны, то среднее число сравнений равно . Однако, если известно, что оно встречается один раз, то достаточно n - 1 сравнений и среднее число сравнений будет равняться

В любом случае, вычислительная сложность алгоритма O(n).