- •Лабораторная работа №1 Основные положения
- •Пример 1. Вычисление площади треугольника
- •Задания
- •Лабораторная работа №2 Функция и обработка события
- •Пример 1. Нахождение площади треугольника.
- •Пример 2. Вычисление площади квадрата.
- •Задания
- •Лабораторная работа №3 Организация ветвлений в программах
- •Пример 1. Нахождение максимального значения
- •Задания
- •Лабораторная работа №4 Методы в JavaScript
- •Пример 1. Перестановка изображений
- •Пример 2. Простое вертикальное меню
- •Задания
- •Лабораторная работа №5 Переключатели
- •Пример 1. Вычисление площади фигуры.
- •Пример 2. Выбор параметров обтекания изображения текстом
- •Задания
- •Лабораторная работа №6 Флажки
- •Пример 1. Выбор характеристик издания
- •Пример 2. Использование флажков в анкете переводчика
- •Листинг 2. Данные, представленные флажком. Анкета переводчика
- •Упражнение
- •Лабораторная работа №7 Списки
- •Пример 1. Обработка анкеты переводчика
- •Пример 2. Тест "Города и памятники"
- •Лабораторная работа №8 Фреймы
- •Пример 1. Простая фреймовая структура
- •Пример 2. Фреймовая структура с загружаемыми документами
- •Пример 3. Обмен содержимым фреймов
- •Задания
- •Лабораторная работа №9 Повторяющиеся вычисления - циклы
- •Пример 1. Нахождение общего делителя
- •Пример 2. Совершенные числа
- •Пример 3. Определение свойств элемента формы
- •Лабораторная работа №10 Обработка и представление дат
- •Пример 1. Определение текущего времени
- •Пример 2. Пятница 13
- •Лабораторная работа №11 Работа со строками
- •Пример 1. Вывод символов строки в "столбик"
- •Пример 2. Вычисление количества повторений строки в тексте
- •Лабораторная работа №12 Массивы
- •Пример 1. Создание мультипликации с использованием массивов.
- •Пример 2. Бинарный поиск с формированием таблицы результатов
Пример 2. Бинарный поиск с формированием таблицы результатов
Напишем функцию, которая реализует алгоритм бинарного поиска таким образом, чтобы во время работы программы формировалась таблица значений переменных i, j, k и некоторых выражений.
Листинг 2. Поиск в упорядоченном массиве с таблицей промежуточных значений
<HTML>
<HEAD>
<TITLE>Бинарный поиск. Таблица промежуточных значений</TITLE>
<script language="JavaScript">
<!-- //
var v=new Array (2, 3, 5, 6, 6, 7,10,11, 20, 25)
function testtab(obj,v,t)
{ var res="i j k v[k] t<= v[k]"+"\r\n"
var i=0
var j= v.length-1
var k
while ( i < j )
{ k=Math.round( (i+j)/2+0.5)-1
res = res + i + " "+j+" "+k+" "+"v[" + k + "]=" + v[k] + " " + t + "<=" + v[k]+"\r\n"
if (t <= v[k] )
j=k
else
i=k+l
}
res += "v[" + i + "]=" +v[i]+"\r\n"
obj.resultl.value=res
if (v[i] == t )
{ return i}
else return -1
}
function test(obj)
{ obj.datal.yalue=v}
//-->
</script>
</HEAD>
<BODY bgcolor=silver>
<H4>Реализация алгоритма бинарного поиска</H4>
<FORM name="forml">
<pre>
Массив:<INPUT type="text" size=40 name="datal" ><hr>
Элемент:<INPUT type="text" size=20 name="data2" ><hr>
Результат поиска: <INPUT type="text" size=20 name="result" ><hr>
Таблица промежуточных значений: <BR>
<textarea cols=50 rows=7 name="result1" > </textarea><hr>
</PRE>
<input type="button" value=0пpeдeлить onClick="test(form1); forml.result.value=testtab(form1,v,forml.data2.value)">
<input type="reset" value=Отменить>
</FORM>
</BODY>
</HTML>
Задания
1. Проверить пример 2 из лабораторной работы. 2. Создать простейший мультипликационный сюжет с использованием массива. 3. Задан одномерный массив вещественных чисел. Напишите сценарий, который определяет число положительных элементов массива. 4. Задан одномерный массив вещественных чисел. Напишите сценарий, позволяющий найти максимальный элемент в массиве.