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

Содержание

Слайд 2

Элементы синтаксиса языка Java

Элементы синтаксиса языка Java

Слайд 3

Hello World!

Любая программа обязательно содержит класс.
Public указывает на доступность класса другим частям

Hello World! Любая программа обязательно содержит класс. Public указывает на доступность класса
программы.
Фигурные скобки называются операторами блока.
Метод main – точка входа в программу.
Статический метод можно использовать без объектов.
Void – не имеет возвращаемого значения.

Слайд 4

String[] args – аргумент командной строки (массив строковых данных).
System.out.println – готовый метод,

String[] args – аргумент командной строки (массив строковых данных). System.out.println – готовый
осуществляющий вывод надписи на экран.

Hello World!

Слайд 5

Примитивные типы данных

Переменные этих типов не являются объектами

Примитивные типы данных Переменные этих типов не являются объектами

Слайд 6

Литералы (константы)

Целочисленные литералы в десятичном виде записываются непосредственно, но литералы типа long

Литералы (константы) Целочисленные литералы в десятичном виде записываются непосредственно, но литералы типа
должны иметь суффикс «L» или «l» (например, 47L).
Литералы типа float должны иметь суффикс «F» или «f» (например, 3.5F), а литералы типа double — суффикс «D» или «d», который может опускаться (3.5D или просто 3.5).
Символьные литералы ограничиваются одинарными кавычками (например, 'ю').
Строковые литералы ограничиваются двойными кавычками ("abcd").
Два логических литерала true и false, не равные целым литералам 1 и 0 соответственно.

Слайд 7

Объявление переменных

Любая переменная может быть инициализирована в момент описания любым допустимым выражением.

Объявление переменных Любая переменная может быть инициализирована в момент описания любым допустимым

Например:
int i = 10;
float f = 3.5f;
char x = ‘f’;
boolean b = false;
Заметьте, что строка должна заканчиваться точкой с запятой.

Слайд 8

Массивы

Массивы в Java являются объектами.
Объявление одномерного массива: к имени переменной либо к

Массивы Массивы в Java являются объектами. Объявление одномерного массива: к имени переменной
имени типа данных добавляются пустые квадратные скобки, например int a[]; или int[] b;
Для создания самого массива (объекта класса «массив», а значит и выделения на него памяти) следует использовать операцию new: a = new int[50];
Возможно одновременное объявление и выделение памяти: int a[] = new int[50];
Возможна также инициализация массива при его создании: int a[] = { 20, 50, 166, 72, 0, –53 };

Слайд 9

Работа с массивами

Для обращения к элементам массива используется операция [].
Элементы массива нумеруются

Работа с массивами Для обращения к элементам массива используется операция []. Элементы
с нуля.
Размеры массива определяются посредством переменной length, вызываемой как метод объекта класса «массив», например a.length возвращает длину массива а.
Многомерные массивы представляют собой массивы массивов и создаются аналогично одномерным, например: int a[][] = new int[5][2];

Слайд 10

Арифметические операции

унарные операции сохранения (+) и изменения знака (–);
унарные операции инкремента

Арифметические операции унарные операции сохранения (+) и изменения знака (–); унарные операции
(++) и декремента (––);
бинарные операции сложения (+), вычитания (–), умножения (*), деления (/) и нахождения остатка от деления (%);
операции с присваиванием (+=, –=, *=, /=, %=). Например, a+=16 эквивалентно a=a+16.
Арифметические операции применяются к числовым типам и имеют результат также числового типа.
Операция деления для целочисленных типов даёт результат целочисленного типа (неполное частное), для вещественных — вещественного.

Слайд 11

Операции сравнения

Операции ==, !=, <, >, <=, >=.
Их результат всегда имеет

Операции сравнения Операции ==, !=, , =. Их результат всегда имеет тип
тип boolean.

Логические операции

унарная операция логического «не» (!),
бинарные операции логического «и» (&&, &), «или» (|, ||) и «исключающего или» (ˆ),
аналогичные операции с присваиванием (&=, |=, ˆ=).
Логические операции применяются к аргументам типа boolean и дают результат типа boolean.

Слайд 12

Условный оператор if

if (<условие>) {
<операторы>}
else {
<операторы>}

Условие должно иметь тип boolean

Условный оператор if if ( ) { } else { } Условие должно иметь тип boolean

Слайд 13

Операторы цикла

for(int i = 0; i < N; ++i) {
<операторы>}

while (<условие>){
<операторы>}

Объявленные в

Операторы цикла for(int i = 0; i } while ( ){ }
операторе переменные действительны лишь внутри цикла

do{
<операторы>
} while (<условие>)

оператор постусловия (сначала выполнит, потом проверит), т.е. даже если условие не выполняется никогда, один раз действие выполнено будет

Слайд 14

Комментарии

можно создавать с помощью двух слешей в конце строки (//)
или с

Комментарии можно создавать с помощью двух слешей в конце строки (//) или
помощью конструкции «/* …. */».

Слайд 15

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

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

Слайд 16

Линейный поиск

Дано: массив А с n элементами.
Выяснить: присутствует ли в массиве

Линейный поиск Дано: массив А с n элементами. Выяснить: присутствует ли в
А значение х. Если да, то мы хотим знать индекс i, такой, что A[i] = х. Если нет – вывести соответствующее сообщение. При этом x может встретиться в массиве более одного раза.
Алгоритм линейного поиска: мы начинаем с начала массива (первого его элемента), поочередно проверяя все его элементы (А[0] затем A[1], затем A[2] и так далее до А[n-1]) и записывая место, где мы находим x (если мы вообще находим его).

Слайд 17

Процедура линейного поиска

Процедура Linear-Search(A,n,x)
Вход:
• A – массив;
• n –

Процедура линейного поиска Процедура Linear-Search(A,n,x) Вход: • A – массив; • n
количество элементов массива А, среди которых выполняется поиск;
• x – искомое значение.
Выход: значение переменной answer – либо индекс i, для которого A[i] = x, либо специальное значение not-found, которое может представлять собой любой некорректный индекс массива, например, произвольное отрицательное значение.

Слайд 18

Шаги процедуры:
1. Установить значение answer равным not-found.
2. Для каждого индекса i,

Шаги процедуры: 1. Установить значение answer равным not-found. 2. Для каждого индекса
пробегающего поочередно значения от 0 до n-1:
А. Если A[i] = x, установить значение answer
равным i.
3. В качестве выходного вернуть значение answer.

Слайд 19

Улучшенный линейный поиск

Прекращаем поиск, как только он находит в массиве значение x.

Процедура

Улучшенный линейный поиск Прекращаем поиск, как только он находит в массиве значение
Better-Linear-Search(A,n,x)
Вход и выход: те же, что и в Linear-Search.
Шаги процедуры:
1. Для i = 0 до n-1:
А. Если A[i] = х, вернуть значение i в качестве
выхода процедуры.
2. Вернуть в качестве выходного значение not-found.

Слайд 20

Поиск с ограничителем

Цель – избежать двойной проверки при каждой итерации цикла. Для

Поиск с ограничителем Цель – избежать двойной проверки при каждой итерации цикла.
этого поместим искомое значение x в последнюю позицию А[n] после сохранения содержимого A[n] в другой переменной. Когда мы находим x, мы выполняем проверку, действительно ли мы его нашли или просто достигли конца массива. Значение, которое мы помещаем в массив, называется ограничителем.

Слайд 21

Процедура Sentinel-Linear-Search(A,n,x)
Вход и выход: те же, что и в Linear-Search.
Шаги

Процедура Sentinel-Linear-Search(A,n,x) Вход и выход: те же, что и в Linear-Search. Шаги
процедуры:
1. Сохранить А[n-1] в переменной last и поместить х в А[n-1].
2. Установить i равным 0.
3. Пока А[i] ≠ x, увеличивать i на 1.
4. Восстановить А[n-1] из переменной last.
5. Если i < n-1 или A[n-1] = x, вернуть значение i в качестве выхода процедуры.
6. В противном случае вернуть в качестве возвращаемого значения not-found.
Имя файла: Алгоритмы-линейного-поиска.pptx
Количество просмотров: 44
Количество скачиваний: 0