АвтоАвтоматизацияАрхитектураАстрономияАудитБиологияБухгалтерияВоенное делоГенетикаГеографияГеологияГосударствоДомДругоеЖурналистика и СМИИзобретательствоИностранные языкиИнформатикаИскусствоИсторияКомпьютерыКулинарияКультураЛексикологияЛитератураЛогикаМаркетингМатематикаМашиностроениеМедицинаМенеджментМеталлы и СваркаМеханикаМузыкаНаселениеОбразованиеОхрана безопасности жизниОхрана ТрудаПедагогикаПолитикаПравоПриборостроениеПрограммированиеПроизводствоПромышленностьПсихологияРадиоРегилияСвязьСоциологияСпортСтандартизацияСтроительствоТехнологииТорговляТуризмФизикаФизиологияФилософияФинансыХимияХозяйствоЦеннообразованиеЧерчениеЭкологияЭконометрикаЭкономикаЭлектроникаЮриспунденкция

Задачи второго класса

Читайте также:
  1. I. ГИМНАСТИКА, ЕЕ ЗАДАЧИ И МЕТОДИЧЕСКИЕ ОСОБЕННОСТИ
  2. I. Ситуационные задачи и тестовые задания.
  3. II. Основные задачи и функции
  4. II. ЦЕЛИ, ЗАДАЧИ И ПРИНЦИПЫ ДЕЯТЕЛЬНОСТИ ВОИ
  5. II. Цель и задачи государственной политики в области развития инновационной системы
  6. III. Цели и задачи социально-экономического развития Республики Карелия на среднесрочную перспективу (2012-2017 годы)
  7. VI. ДАЛЬНЕЙШИЕ ЗАДАЧИ И ПУТИ ИССЛЕДОВАНИЯ
  8. Активные интегрированные антенны для усилителей класса F
  9. Аналитические возможности, задачи и основные направления анализа СНС
  10. Аналитическое выравнивание по параболе второго порядка
  11. БАЛАНС КОММЕРЧЕСКОГО БАНКА, ЦЕЛИ И ЗАДАЧИ ЕГО АНАЛИЗА
  12. Билет 1. Предмет истории как науки: цели и задачи ее изучения

Особенностью задач этого класса является изменение порядка следования элементов массива. Для этого часто приходится менять местами элементы массива. Поэтому необходимо ввести дополнительную переменную, для того, чтобы не потерять старое значение элемента массива. Это выполняется с помощью приведенных ниже операторов.

Задача 1. Поменяйте местами значения переменных a[i] и a[j].

Решение.

r:= a[i]; {запомнили a[i] во вспомогательной переменной}

a[i]:= a[j]; { записали значение a[j] на место a[i], старое значение

последнего потерялось, но сохранилась его копия в

переменной r}

a[j]:=r; { записали запомненное значение a[i] на место a[j]}

Задача 2. Переверните массив, т.е. запишите элементы массива в обратном порядке.

Решение. Для решения этой задачи необходимо поменять местами первый и последний, второй и предпоследний и т.д. элементы. Этот процесс нужно продолжать до тех пор, пока не дойдем до середины массива, иначе массив будет перевернут дважды и получим исходное расположение элементов. Для решения этой задачи хорошо подходит схема перебора элементов массива по два при движении с обеих сторон.

i:= 1; j:= n;

while i <= j do

begin

r:= a[i];

a[i]:= a[j];

a[j]:= r;

i:= i + 1; j:= j +1

end;

Упражнение. Внесите изменения в приведенный выше фрагмент программы для того, чтобы переворачивалась часть массива от элемента с номером p до элемента с номером q, не используя при этом дополнительный массив.

Задача 3. Поменяйте местами пары соседних элементов, т.е. первый и второй, третий и четвертый и т.д. (n-1)-ый и n-ый.

Решение. В этой задаче используется схема обмена элементов при схеме перебора с шагом два.

i:= 2;

while i < n do

begin

r:= a[i];

a[i]:= a[i+1];

a[i+1]:= r;

i:= i + 2

end;

Задача 4. Циклически сдвиньте элементы массива на один элемент влево.

Решение. Циклический сдвиг означает, что происходит следующая замена: первый элемент заменяется вторым, второй - третьим и т.д., последний - старым значением первого. При этом можно потерять только значение первого элемента, которое и необходимо сохранить перед циклом.

r:= a[1];

for i:= 1 to n-1 do

a[i]:= a[i + 1];

a[n]:= r;

Задача 5. Сдвиньте циклически элементы массива на k позиций влево.

Решение. Можно воспользоваться предыдущим решением, повторив k раз сдвиг на один элемент.

for j:= 1 to k do

begin

r:= a[1];

for i:= 1 to n - 1 do

a[i]:= a[i + 1];

a[n]:= r

end.

Можно решить эту задачу с использованием вспомогательного массива, в котором будут сохранены первые k элементов. Затем, после сдвига оставшихся элементов на k позиций влево, в оставшиеся позиции будут переписаны элементы из вспомогательного массива.

for i:= 1 to k do

b[i]:= a[i];

for i:= 1 to n - k do

a[i]:= a[i + k];

for i:= n- k + 1 to n do

a[i]:= b[i - k + 1];

Упражнение. Напишите программу циклического сдвига одномерного массива вправо на k элементов.


1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 |

Поиск по сайту:



Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Студалл.Орг (0.003 сек.)