Разделы презентаций


Программирование на языке Паскаль

Содержание

Программирование на языке Паскаль§ 62. Массивы

Слайды и текст этой презентации

Слайд 1Программирование на языке Паскаль
§ 62. Массивы
§ 63. Алгоритмы обработки массивов
§

64. Сортировка
§ 65. Двоичный поиск
§ 66. Символьные строки
§ 67. Матрицы
§

68. Работа с файлами
Программирование на языке Паскаль§ 62. Массивы§ 63. Алгоритмы обработки массивов§ 64. Сортировка§ 65. Двоичный поиск§ 66. Символьные

Слайд 2Программирование на языке Паскаль
§ 62. Массивы

Программирование на языке Паскаль§ 62. Массивы

Слайд 3Что такое массив?
Массив – это группа переменных одного типа, расположенных

в памяти рядом (в соседних ячейках) и имеющих общее имя.

Каждая ячейка в массиве имеет уникальный номер.

Надо:

выделять память
записывать данные в нужную ячейку
читать данные из ячейки

Что такое массив?Массив – это группа переменных одного типа, расположенных в памяти рядом (в соседних ячейках) и

Слайд 4Выделение памяти (объявление)
var A: array[1..5] of integer;
V: array[0..5] of real;
L:

array[-5..5] of boolean;
S: array[65..90] of char;
минимальный индекс
максимальный индекс
const N =

10;
var A: array[1..N] of integer;

размер через константу

Выделение памяти (объявление)var A: array[1..5] of integer;	V: array[0..5] of real;	L: array[-5..5] of boolean;	S: array[65..90] of char;минимальный индексмаксимальный

Слайд 5Что неправильно?
var A: array[10..1] of integer;
...
A[5] := 4.5;
[1..10]
var A: array[1..10]

of integer;
...
A[15] := 'a'
var a: array ['z'..'a'] of integer;
...
A['B']

:= 15;

A['b']

['a'..'z']

Что неправильно?var A: array[10..1] of integer;...A[5] := 4.5;[1..10]var A: array[1..10] of integer;...A[15] := 'a'var a: array ['z'..'a']

Слайд 6Обращение к элементу массива
A
массив
3
15
НОМЕР элемента массива
(ИНДЕКС)
A[1]
A[2]
A[3]
A[4]
A[5]
ЗНАЧЕНИЕ элемента массива
A[2]
НОМЕР (ИНДЕКС) элемента

массива: 2
ЗНАЧЕНИЕ элемента массива: 10

Обращение к элементу массиваAмассив315НОМЕР  элемента массива(ИНДЕКС)A[1]A[2]A[3]A[4]A[5]ЗНАЧЕНИЕ элемента массиваA[2]НОМЕР (ИНДЕКС)  элемента массива: 2ЗНАЧЕНИЕ  элемента массива:

Слайд 7Как обработать все элементы массива?
Объявление:



Обработка:
const N = 5;
var A: array[1..N]

of integer;
{ обработать A[1] }
{ обработать A[2] }
{ обработать A[3]

}
{ обработать A[4] }
{ обработать A[5] }
Как обработать все элементы массива?Объявление:Обработка:const N = 5;var A: array[1..N] of integer;{ обработать A[1] }{ обработать A[2]

Слайд 8Как обработать все элементы массива?
Обработка с переменной:
i:= 1;
{ обработать A[i]

}
i:= i + 1;
{ обработать A[i] }
i:= i + 1;
{

обработать A[i] }
i:= i + 1;
{ обработать A[i] }
i:= i + 1;
{ обработать A[i] }

i:= i + 1;

Обработка в цикле:

i:= 1;
while i <= N do begin
{ обработать A[i] }
i:= i + 1;
end;

Цикл с переменной:

for i:=1 to N do begin
{ обработать A[i] }
end;

Как обработать все элементы массива?Обработка с переменной:i:= 1;{ обработать A[i] }i:= i + 1;{ обработать A[i] }i:=

Слайд 9Заполнение массива
program Arr;
const N = 10;
var A: array[1..N] of integer;

i: integer;
begin
for i:=1 to N do
A[i]:=

i*i;
end.
Заполнение массиваprogram Arr;const N = 10;var A: array[1..N] of integer;  i: integer;begin for i:=1 to N

Слайд 10Ввод с клавиатуры и вывод на экран
Объявление:





Ввод с клавиатуры:
Вывод на

экран:
const N = 5;
var A: array[1..N] of integer;

i: integer;

for i:=1 to N do begin
write('A[', i, ']=');
read ( A[i] )
end;

A[1] =
A[2] =
A[3] =
A[4] =
A[5] =

5
12
34
56
13

writeln('Массив A:');
for i:=1 to N do write(A[i]:4);

Ввод с клавиатуры и вывод на экранОбъявление:Ввод с клавиатуры:Вывод на экран:const N = 5; var A: array[1..N]

Слайд 11Заполнение случайными числами
for i:=1 to N do begin
A[i]:= 20

+ random(81);
write(A[i],' ')
end;
Задача. Заполнить массив (псевдо)случайными целыми числами

в диапазоне от 20 до 100.
Заполнение случайными числамиfor i:=1 to N do begin A[i]:= 20 + random(81); write(A[i],' ')end; Задача. Заполнить массив

Слайд 12Перебор элементов
Общая схема:
for i:=1 to N do begin
... {

сделать что-то с A[i] }
end;
Подсчёт нужных элементов:
Задача. В массиве записаны

данные о росте баскетболистов. Сколько из них имеет рост больше 180 см, но меньше 190 см?

count:= 0;
for i:=1 to N do
if (180 < A[i]) and (A[i] < 190) then
count:= count + 1;

Перебор элементовОбщая схема:for i:=1 to N do begin ... { сделать что-то с A[i] }end;Подсчёт нужных элементов:Задача.

Слайд 13Перебор элементов
Среднее арифметическое:
count:= 0; sum:= 0;
for i:=1 to N do

if (180 < A[i]) and (A[i] < 190)
then begin

count:= count + 1;
sum:= sum + A[i]
end;
write(sum/count);

среднее арифметическое

Перебор элементовСреднее арифметическое:count:= 0; sum:= 0;for i:=1 to N do if (180 < A[i]) and (A[i] <

Слайд 14Задачи
«A»: Заполните массив случайными числами в интервале [0,100] и найдите

среднее арифметическое его значений.
Пример:
Массив:
1 2 3 4 5
Среднее арифметическое

3.000

«B»: Заполните массив случайными числами в интервале [0,100] и подсчитайте отдельно среднее значение всех элементов, которые <50, и среднее значение всех элементов, которые ≥50.
Пример:
Массив:
3 2 52 4 60
Ср. арифм. элементов [0,50): 3.000
Ср. арифм. элементов [50,100): 56.000

Задачи«A»: Заполните массив случайными числами в интервале [0,100] и найдите среднее арифметическое его значений. Пример:Массив:1 2 3

Слайд 15Задачи
«C»: Заполните массив из N элементов случайными числами в интервале

[1,N] так, чтобы в массив обязательно вошли все числа от

1 до N (постройте случайную перестановку).
Пример:
Массив:
3 2 1 4 5
Задачи«C»: Заполните массив из N элементов случайными числами в интервале [1,N] так, чтобы в массив обязательно вошли

Слайд 16Программирование на языке Паскаль
§ 63. Алгоритмы обработки массивов

Программирование на языке Паскаль§ 63. Алгоритмы обработки массивов

Слайд 17Поиск в массиве
Найти элемент, равный X:
i:= 1;
while A[i] X

do
i:= i + 1;
write('A[',i,']=',X);
i:= 1;
while

and (A[i] <> X) do
i:= i + 1;
if i <= N then
write('A[',i,']=',X)
else write('Не нашли!');

(i <= N)

должно быть первым!

Поиск в массивеНайти элемент, равный X:i:= 1;while A[i] X do i:= i + 1;write('A[',i,']=',X);i:= 1;while

Слайд 18Поиск в массиве
nX:= 0;
for i:=1 to N do
if A[i]

= X then begin
nX:= i;

end;
if

nX > 0 then
write('A[',i,']=',X)
else write('Не нашли!');

Вариант с досрочным выходом:

break

досрочный выход из цикла

Поиск в массивеnX:= 0;for i:=1 to N do if A[i] = X then begin  nX:= i;

Слайд 19Задачи
«A»: Заполните массив случайными числами в интервале [0,5]. Введите число

X и найдите все значения, равные X.
Пример:
Массив:
1 2 3

1 2
Что ищем:
2
Нашли: A[2]=2, A[5]=2
Пример:
Массив:
1 2 3 1 2
Что ищем:
6
Ничего не нашли.
Задачи«A»: Заполните массив случайными числами в интервале [0,5]. Введите число X и найдите все значения, равные X.

Слайд 20Задачи
«B»: Заполните массив случайными числами в интервале [0,5]. Определить, есть

ли в нем элементы с одинаковыми значениями, стоящие рядом.
Пример:
Массив:
1

2 3 3 2 1
Есть: 3
Пример:
Массив:
1 2 3 4 2 1
Нет
Задачи«B»: Заполните массив случайными числами в интервале [0,5]. Определить, есть ли в нем элементы с одинаковыми значениями,

Слайд 21Задачи
«C»: Заполните массив случайными числами. Определить, есть ли в нем

элементы с одинаковыми значениями, не обязательно стоящие рядом.
Пример:
Массив:
3 2 1

3 2 5
Есть: 3, 2
Пример:
Массив:
3 2 1 4 0 5
Нет
Задачи«C»: Заполните массив случайными числами. Определить, есть ли в нем элементы с одинаковыми значениями, не обязательно стоящие

Слайд 22Максимальный элемент
M:= A[1];
for i:= 2 to N do
if A[i]

> M then
M:= A[i];
write(M);

Максимальный элементM:= A[1];for i:= 2 to N do if A[i] > M then  M:= A[i];write(M);

Слайд 23Максимальный элемент и его номер

Максимальный элемент и его номер

Слайд 24Задачи
«A»: Заполнить массив случайными числами и найти минимальный и максимальный

элементы массива и их номера.
Пример:
Массив:
1 2 3 4 5
Минимальный

элемент: A[1]=1
Максимальный элемент: A[5]=5

«B»: Заполнить массив случайными числами и найти два максимальных элемента массива и их номера.
Пример:
Массив:
5 5 3 4 1
Максимальный элемент: A[1]=5
Второй максимум: A[2]=5

Задачи«A»: Заполнить массив случайными числами и найти минимальный и максимальный элементы массива и их номера. Пример:Массив:1 2

Слайд 25Задачи
«C»: Введите массив с клавиатуры и найдите (за один проход)

количество элементов, имеющих максимальное значение.
Пример:
Массив:
3 4 5 5 3

4 5
Максимальное значение 5
Количество элементов 3
Задачи«C»: Введите массив с клавиатуры и найдите (за один проход) количество элементов, имеющих максимальное значение. Пример:Массив:3 4

Слайд 26Реверс массива
«Простое» решение:
for i:= 1 to N

do
поменять местами A[i] и A[N+1-i]
N div 2
остановиться на

середине!
Реверс массива«Простое» решение:for i:= 1 to N    do  поменять местами A[i] и A[N+1-i]N

Слайд 27Реверс массива
for i:= 1 to N div 2 do begin

c:= A[i];
A[i]:= A[N+1-i];
A[N+1-i]:= c;
end;

Реверс массиваfor i:= 1 to N div 2 do begin c:= A[i]; A[i]:= A[N+1-i]; A[N+1-i]:= c;end;

Слайд 28Циклический сдвиг элементов
«Простое» решение:
c:= A[1];
for i:= 1 to N-1 do

A[i]:= A[i+1]
A[N]:= c;

Циклический сдвиг элементов«Простое» решение:c:= A[1];for i:= 1 to N-1 do A[i]:= A[i+1]A[N]:= c;

Слайд 29Задачи
«A»: Заполнить массив случайными числами и выполнить циклический сдвиг элементов

массива вправо на 1 элемент.
Пример:
Массив:
1 2 3 4 5

6
Результат:
6 1 2 3 4 5

«B»: Массив имеет четное число элементов. Заполнить массив случайными числами и выполнить реверс отдельно в первой половине и второй половине.
Пример:
Массив:
1 2 3 4 5 6
Результат:
3 2 1 6 5 4

Задачи«A»: Заполнить массив случайными числами и выполнить циклический сдвиг элементов массива вправо на 1 элемент. Пример:Массив:1 2

Слайд 30Задачи
«C»: Заполнить массив случайными числами в интервале [-100,100] и переставить

элементы так, чтобы все положительные элементы стояли в начала массива,

а все отрицательные и нули – в конце. Вычислите количество положительных элементов.
Пример:
Массив:
20 -90 15 -34 10 0
Результат:
20 15 10 -90 -34 0
Количество положительных элементов: 3
Задачи«C»: Заполнить массив случайными числами в интервале [-100,100] и переставить элементы так, чтобы все положительные элементы стояли

Слайд 31Отбор нужных элементов
«Простое» решение:
Задача. Отобрать элементы массива A, удовлетворяющие некоторому

условию, в массив B.
for i:= 1 to N do
if

условие выполняется для A[i] then
B[i]:= A[i];

A

B

выбрать чётные элементы

Отбор нужных элементов«Простое» решение:Задача. Отобрать элементы массива A, удовлетворяющие некоторому условию, в массив B.for i:= 1 to

Слайд 32Отбор нужных элементов
A
B
выбрать чётные элементы
count:= 0; { счётчик }
for i:=

1 to N do
if A[i] mod 2 = 0

then begin
count:= count + 1;

end;

B[count]:= A[i];

Отбор нужных элементовABвыбрать чётные элементыcount:= 0; { счётчик }for i:= 1 to N do if A[i] mod

Слайд 33Задачи
«A»: Заполнить массив случайными числами в интервале [-10,10] и отобрать

в другой массив все чётные отрицательные числа.
Пример:
Массив А:
-5 6 7

-4 -6 8 -8
Массив B:
-4 -6 -8

«B»: Заполнить массив случайными числами в интервале [0,100] и отобрать в другой массив все простые числа. Используйте логическую функцию, которая определяет, является ли переданное ей число простым.
Пример:
Массив А:
12 13 85 96 47
Массив B:
13 47

Задачи«A»: Заполнить массив случайными числами в интервале  [-10,10] и отобрать в другой массив все чётные отрицательные

Слайд 34Задачи
«C»: Заполнить массив случайными числами и отобрать в другой массив

все числа Фибоначчи. Используйте логическую функцию, которая определяет, является ли

переданное ей число числом Фибоначчи.
Пример:
Массив А:
12 13 85 34 47
Массив B:
13 34
Задачи«C»: Заполнить массив случайными числами и отобрать в другой массив все числа Фибоначчи. Используйте логическую функцию, которая

Слайд 35Программирование на языке Паскаль
§ 64. Сортировка

Программирование на языке Паскаль§ 64. Сортировка

Слайд 36Что такое сортировка?
Сортировка – это расстановка элементов массива в заданном

порядке.
…по возрастанию, убыванию, последней цифре, сумме делителей, по алфавиту, …
Алгоритмы:
простые

и понятные, но неэффективные для больших массивов
метод пузырька
метод выбора
сложные, но эффективные
«быстрая сортировка» (QuickSort)
сортировка «кучей» (HeapSort)
сортировка слиянием (MergeSort)
пирамидальная сортировка
Что такое сортировка?Сортировка – это расстановка элементов массива в заданном порядке.…по возрастанию, убыванию, последней цифре, сумме делителей,

Слайд 37Метод пузырька (сортировка обменами)
Идея: пузырек воздуха в стакане воды поднимается

со дна вверх.
Для массивов – самый маленький («легкий» элемент

перемещается вверх («всплывает»).

сравниваем два соседних элемента; если они стоят «неправильно», меняем их местами
за 1 проход по массиву один элемент (самый маленький) становится на свое место

1-й проход:

Метод пузырька (сортировка обменами)Идея: пузырек воздуха в стакане воды поднимается со дна вверх. Для массивов – самый

Слайд 38Метод пузырька
2-й проход:
3-й проход:
4-й проход:

Метод пузырька2-й проход:3-й проход:4-й проход:

Слайд 39Метод пузырька
1-й проход:
for j:= N-1 downto 1 do
if A[j+1]

A[j] then begin
{ поменять местами A[j] и A[j+1]

}
end;

2-й проход:

for j:= N-1 downto do
if A[j+1]< A[j] then begin
{ поменять местами A[j] и A[j+1] }
end;

2

единственное отличие!

Метод пузырька1-й проход:for j:= N-1 downto 1 do if A[j+1]< A[j] then begin  { поменять местами

Слайд 40Метод пузырька
for i:= 1 to N-1 do
for j:= N-1

downto do
if A[j+1]< A[j] then begin

{ поменять местами A[j] и A[j+1] }
end;

i

Метод пузырькаfor i:= 1 to N-1 do for j:= N-1 downto  do  if A[j+1]< A[j]

Слайд 41Задачи
«A»: Напишите программу, в которой сортировка выполняется «методом камня» –

самый «тяжёлый» элемент опускается в конец массива.
«B»: Напишите вариант метода

пузырька, который заканчивает работу, если на очередном шаге внешнего цикла не было перестановок.

«С»: Напишите программу, которая сортирует массив по убыванию суммы цифр числа. Используйте функцию, которая определяет сумму цифр числа.

Задачи«A»: Напишите программу, в которой сортировка выполняется «методом камня» – самый «тяжёлый» элемент опускается в конец массива.«B»:

Слайд 42Метод выбора (минимального элемента)
Идея: найти минимальный элемент и поставить его

на первое место.
for i:= 1 to N-1 do begin

{ найти номер nMin минимального элемента из A[i]..A[N] }
if i <> nMin then begin
{ поменять местами A[i] и A[nMin] }
end
end;
Метод выбора (минимального элемента)Идея: найти минимальный элемент и поставить его на первое место. for i:= 1 to

Слайд 43Метод выбора (минимального элемента)
for i:= 1 to N-1 do begin





if i nMin then begin
{ поменять местами

A[i] и A[nMin] }
end
end;

nMin:= i;
for j:=i+1 to N do
if A[j] < A[nMin] then
nMin:= j;

Метод выбора (минимального элемента)for i:= 1 to N-1 do begin if i nMin then begin  {

Слайд 44Задачи
«A»: Массив содержит четное количество элементов. Напишите программу, которая сортирует

первую половину массива по возрастанию, а вторую – по убыванию.

Каждый элемент должен остаться в «своей» половине.
Пример:
Массив:
5 3 4 2 1 6 3 2
После сортировки:
2 3 4 5 6 3 2 1
Задачи«A»: Массив содержит четное количество элементов. Напишите программу, которая сортирует первую половину массива по возрастанию, а вторую

Слайд 45Задачи
«B»: Напишите программу, которая сортирует массив и находит количество различных

чисел в нем.
Пример:
Массив:
5 3 4 2 1 6 3

2 4
После сортировки:
1 2 2 3 3 4 4 5 6
Различных чисел: 5

«C»: Напишите программу, которая сравнивает число перестановок элементов при использовании сортировки «пузырьком» и методом выбора. Проверьте ее на разных массивах, содержащих 1000 случайных элементов, вычислите среднее число перестановок для каждого метода.

Задачи«B»: Напишите программу, которая сортирует массив и находит количество различных чисел в нем. Пример:Массив:5 3 4 2

Слайд 46Быстрая сортировка (QuickSort)
Идея: выгоднее переставлять элементы, который находятся дальше друг

от друга.

Быстрая сортировка (QuickSort)Идея: выгоднее переставлять элементы, который находятся дальше друг от друга.

Слайд 47Быстрая сортировка
Шаг 2: переставить элементы так:

при сортировке элементы

не покидают « свою область»!
Шаг 1: выбрать некоторый элемент массива

X

Шаг 3: так же отсортировать две получившиеся области

Разделяй и властвуй (англ. divide and conquer)

Медиана – такое значение X, что слева и справа от него в отсортированном массиве стоит одинаковое число элементов (для этого надо отсортировать массив…).

Быстрая сортировкаШаг 2: переставить элементы так:   при сортировке элементы не покидают « свою область»!Шаг 1:

Слайд 48Быстрая сортировка
Разделение:
выбрать средний элемент массива (X=67)


установить L:=1, R:=N
увеличивая L,

найти первый элемент A[L], который >= X (должен стоять справа)
уменьшая

R, найти первый элемент A[R], который <= X (должен стоять слева)
если L<=R то поменять местами A[L] и A[R] и перейти к п. 3 иначе стоп.
Быстрая сортировкаРазделение: выбрать средний элемент массива (X=67)установить L:=1, R:=Nувеличивая L, найти первый элемент A[L],  который >=

Слайд 49Быстрая сортировка

Быстрая сортировка

Слайд 50Быстрая сортировка
program QuickSort;
const N = 7;
var A: array[1..N] of integer;
...
begin

{ заполнить массив }
qSort(1, N); { сортировка }
{

вывести результат }
end;

Основная программа:

глобальные данные

Быстрая сортировкаprogram QuickSort;const N = 7;var A: array[1..N] of integer;...begin { заполнить массив } qSort(1, N); {

Слайд 51Быстрая сортировка
procedure qSort(nStart, nEnd: integer);
var L, R, c, X: integer;
begin

if nStart >= nEnd then Exit;
L:= nStart; R:= nEnd;

X:= A[(L+R) div 2]; { или X:= A[L+random(R-L+1)] }
while L <= R do begin { разделение }
while A[L] < X do L:= L + 1;
while A[R] > X do R:= R - 1;
if L <= R then begin
c:= A[L]; A[L]:= A[R]; A[R]:= c;
L:= L+1; R:= R-1
end
end;
qSort(nStart, R); { рекурсивные вызовы }
qSort(L, nEnd)
end;
Быстрая сортировкаprocedure qSort(nStart, nEnd: integer);var L, R, c, X: integer;begin if nStart >= nEnd then Exit; L:=

Слайд 52Быстрая сортировка
Сортировка массива случайных значений:

Быстрая сортировкаСортировка массива случайных значений:

Слайд 53Задачи
«B»: Напишите программу, которая сортирует массив и находит количество различных

чисел в нем. Используйте алгоритм быстрой сортировки.
Пример:
Массив:
5 3 4 2

1 6 3 2 4
После сортировки:
1 2 2 3 3 4 4 5 6
Различных чисел: 5
Задачи«B»: Напишите программу, которая сортирует массив и находит количество различных чисел в нем. Используйте алгоритм быстрой сортировки.Пример:Массив:5

Слайд 54Задачи
«C»: Напишите программу, которая сравнивает число перестановок элементов при использовании

сортировки «пузырьком», методом выбора и алгоритма быстрой сортировки. Проверьте ее

на разных массивах, содержащих 1000 случайных элементов, вычислите среднее число перестановок для каждого метода.

«D»: Попробуйте построить массив из 10 элементов, на котором алгоритм быстрой сортировки показывает худшую эффективность (наибольшее число перестановок). Сравните это количество перестановок с эффективностью метода пузырька (для того же массива).

Задачи«C»: Напишите программу, которая сравнивает число перестановок элементов при использовании сортировки «пузырьком», методом выбора и алгоритма быстрой

Слайд 55Программирование на языке Паскаль
§ 65. Двоичный поиск

Программирование на языке Паскаль§ 65. Двоичный поиск

Слайд 56Двоичный поиск
X = 7
X < 8
8
4
X > 4
6
X > 6
Выбрать

средний элемент A[c] и сравнить с X.
Если X = A[c],

то нашли (стоп).
Если X < A[c], искать дальше в первой половине.
Если X > A[c], искать дальше во второй половине.
Двоичный поискX = 7X < 884X > 46X > 6Выбрать средний элемент A[c] и сравнить с X.Если

Слайд 57Двоичный поиск
X = 44

Двоичный поискX = 44

Слайд 58Двоичный поиск
var L, R, c: integer;
...
L:= 1; R:= N +

1; { начальный диапазон }
while L < R-1 do begin

c:= (L+R) div 2; { нашли середину }
if X < A[c] then
R:= c { изменить диапазон }
else L:= c;
end;
if A[L] = X then
writeln('A[',L,']=',X)
else writeln('Не нашли!')
Двоичный поискvar L, R, c: integer;...L:= 1; R:= N + 1; { начальный диапазон }while L <

Слайд 59Двоичный поиск
скорость выше, чем при линейном поиске
нужна предварительная сортировка
Число сравнений:

Двоичный поискскорость выше, чем при линейном поискенужна предварительная сортировкаЧисло сравнений:

Слайд 60Задачи
«A»: Заполнить массив случайными числами и отсортировать его. Ввести число

X. Используя двоичный поиск, определить, есть ли в массиве число,

равное X. Подсчитать количество сравнений.
Пример:
Массив:
1 4 7 3 9 2 4 5 2
После сортировки:
1 2 2 3 4 4 5 7 9
Введите число X:
2
Число 2 найдено.
Количество сравнений: 2
Задачи«A»: Заполнить массив случайными числами и отсортировать его. Ввести число X. Используя двоичный поиск, определить, есть ли

Слайд 61Задачи
«B»: Заполнить массив случайными числами и отсортировать его. Ввести число

X. Используя двоичный поиск, определить, сколько чисел, равных X, находится

в массиве.
Пример:
Массив:
1 4 7 3 9 2 4 5 2
После сортировки:
1 2 2 3 4 4 5 7 9
Введите число X:
4
Число 4 встречается 2 раз(а).
Пример:
Массив:
1 4 7 3 9 2 4 5 2
После сортировки:
1 2 2 3 4 4 5 7 9
Введите число X:
14
Число 14 не встречается.
Задачи«B»: Заполнить массив случайными числами и отсортировать его. Ввести число X. Используя двоичный поиск, определить, сколько чисел,

Слайд 62Задачи
«C»: Заполнить массив случайными числами и ввести число и отсортировать

его. Ввести число X. Используя двоичный поиск, определить, есть ли

в массиве число, равное X. Если такого числа нет, вывести число, ближайшее к X.
Пример:
Массив:
1 4 7 3 9 2 4 5 2
После сортировки:
1 2 2 3 4 4 5 12 19
Введите число X:
12
Число 12 найдено.
Пример:
Массив:
1 4 7 3 9 2 4 5 2
После сортировки:
1 2 2 3 4 4 5 12 19
Введите число X:
11
Число 11 не найдено. Ближайшее число 12.
Задачи«C»: Заполнить массив случайными числами и ввести число и отсортировать его. Ввести число X. Используя двоичный поиск,

Слайд 63Программирование на языке Паскаль
§ 66. Символьные строки

Программирование на языке Паскаль§ 66. Символьные строки

Слайд 64Зачем нужны символьные строки?
var s: array[1..80] of char;

{ массив символов }
элементы массива – отдельные объекты
сложно

работать со строками переменной длины

Хочется:
строка – единый объект
длина строки может меняться во время работы программы

var s: string; { символьная строка }

строка

Зачем нужны символьные строки?var s: array[1..80] of char;    { массив символов }элементы массива –

Слайд 65Символьные строки
Присваивание:
s:= 'Вася пошёл гулять';
Ввод с клавиатуры:
readln(s);
Вывод на экран:
writeln(s);
Отдельный символ:
s[4]:=

'a';
Длина строки:
var n: integer;
...
n:= Length(s);
var s: string;

Символьные строкиПрисваивание:s:= 'Вася пошёл гулять';Ввод с клавиатуры:readln(s);Вывод на экран:writeln(s);Отдельный символ:s[4]:= 'a';Длина строки:var n: integer;...n:= Length(s);var s: string;

Слайд 66Символьные строки
program ReplaceAB;
var s: string;
i: integer;
begin
writeln('Введите

строку');
readln(s);
for i:=1 to Length(s) do

if s[i]= 'а' then
s[i]:= 'б';
writeln(s);
end.

Задача: заменить в строке все буквы 'а' на буквы 'б'.

Символьные строкиprogram ReplaceAB;var s: string;  i: integer;begin  writeln('Введите строку');  readln(s);  for i:=1 to

Слайд 67Задачи
«A»: Ввести с клавиатуры символьную строку и заменить в ней

все буквы «а» на «б» и все буквы «б» на

«а» (заглавные на заглавные, строчные на строчные).
Пример:
Введите строку:
ааббААББссСС
Результат:
ббааББААссСС
Задачи«A»: Ввести с клавиатуры символьную строку и заменить в ней все буквы «а» на «б» и все

Слайд 68Задачи
«B»: Ввести с клавиатуры символьную строку и определить, сколько в

ней слов. Словом считается последовательности непробельных символов, отделенная с двух

сторон пробелами (или стоящая с краю строки). Слова могут быть разделены несколькими пробелами, в начале и в конце строки тоже могут быть пробелы.
Пример:
Введите строку:
Вася пошел гулять
Найдено слов: 3
Задачи«B»: Ввести с клавиатуры символьную строку и определить, сколько в ней слов. Словом считается последовательности непробельных символов,

Слайд 69Задачи
«C»: Ввести с клавиатуры символьную строку и найдите самое длинное

слово и его длину. Словом считается последовательности непробельных символов, отделенная

с двух сторон пробелами (или стоящая с краю строки). Слова могут быть разделены несколькими пробелами, в начале и в конце строки тоже могут быть пробелы.
Пример:
Введите строку:
Вася пошел гулять
Самое длинное слово: гулять, длина 6
Задачи«C»: Ввести с клавиатуры символьную строку и найдите самое длинное слово и его длину. Словом считается последовательности

Слайд 70Операции со строками
Объединение (конкатенация) :
s1:= 'Привет';
s2:= 'Вася';
s :=

s1 + ', ' + s2 + '!';
'Привет, Вася!'
Срез:
s:=

'123456789';
s1:= Copy(s, 3, 5); { '34567' }

с какого символа

откуда

5

Операции со строкамиОбъединение (конкатенация) :s1:= 'Привет'; s2:= 'Вася'; s := s1 + ', ' + s2 +

Слайд 71Операции со строками
Вставка:
s:= '123456789';
Insert('ABC', s, 3); { '12ABC3456789' }
что
куда
с какого

символа
Удаление:
s:= '123456789';
Delete(s, 3, 6); { '129' }
с какого символа
сколько символов

Операции со строкамиВставка:s:= '123456789';Insert('ABC', s, 3); { '12ABC3456789' }чтокудас какого символаУдаление:s:= '123456789';Delete(s, 3, 6); { '129' }с

Слайд 72Поиск в строках
s:= 'Здесь был Вася.';

n:= Pos('с', s)
if n >

0 then
write('Номер символа ', n)
else
write('Символ не найден.');
что
где

Поиск в строкахs:= 'Здесь был Вася.';n:= Pos('с', s)if n > 0 then write('Номер символа ', n)else write('Символ

Слайд 73Пример обработки строк
Задача: Ввести имя, отчество и фамилию. Преобразовать их

к формату «фамилия-инициалы».
Пример:
Введите имя, отчество и фамилию:

Василий Алибабаевич Хрюндиков
Результат:
Хрюндиков В.А.

Алгоритм:
найти первый пробел и выделить имя
удалить имя с пробелом из основной строки
найти первый пробел и выделить отчество
удалить отчество с пробелом из основной строки
«сцепить» фамилию, первые буквы имени и фамилии, точки, пробелы…

Алибабаевич Хрюндиков

Хрюндиков

Хрюндиков В.А.

Пример обработки строкЗадача: Ввести имя, отчество и фамилию. Преобразовать их к формату «фамилия-инициалы».  Пример:	 Введите имя,

Слайд 74Пример обработки строк
program FIO;
var s, name, name2: string;
n:

integer;
begin
write('Введите имя, отчество и фамилию: ');
readln(s);

n:= Pos(' ', s);
name:= Copy(s, 1, n-1); { взять имя }
Delete(s, 1, n);
n:= Pos(' ', s);
name2:= Copy(s, 1, n-1);{ взять отчество }
Delete(s, 1, n); { осталась фамилия }
s:= s + ' ' + name[1] + '.' + name2[1] + '.';
writeln(s)
end.
Пример обработки строкprogram FIO;var s, name, name2: string;  n: integer;begin  write('Введите имя, отчество и фамилию:

Слайд 75Задачи
«A»: Ввести с клавиатуры в одну строку фамилию, имя и

отчество, разделив их пробелом. Вывести фамилию и инициалы.
Пример:
Введите фамилию, имя

и отчество:
Иванов Петр Семёнович
П.С. Иванов
Задачи«A»: Ввести с клавиатуры в одну строку фамилию, имя и отчество, разделив их пробелом. Вывести фамилию и

Слайд 76Задачи
«B»: Ввести адрес файла и «разобрать» его на части, разделенные

знаком '/'. Каждую часть вывести в отдельной строке.
Пример:
Введите адрес файла:
C:/Фото/2013/Поход/vasya.jpg
C:
Фото
2013
Поход
vasya.jpg

Задачи«B»: Ввести адрес файла и «разобрать» его на части, разделенные знаком '/'. Каждую часть вывести в отдельной

Слайд 77Задачи
«C»: Напишите программу, которая заменяет во всей строке одну последовательность

символов на другую.
Пример:
Введите строку:
(X > 0) and (Y < X)

and (Z > Y) and (Z <> 5)
Что меняем: and
Чем заменить: &
Результат
(X > 0) & (Y < X) & (Z > Y) & (Z <> 5)
Задачи«C»: Напишите программу, которая заменяет во всей строке одну последовательность символов на другую.Пример:Введите строку:(X > 0) and

Слайд 78Преобразования «строка» – «число»
Из строки в число:
s:= '123';
Val(s, N,

r); { N = 123 }
s:= '123.456';
Val(s, X, r); {

X = 123.456 }

Из числа в строку:

N:= 123;
Str(N, s); { s = '123' }
X:= 123.456;
Str(X, s); { s ='1.234560E+002' }
Str(X:10:3, s); { s = ' 123.456' }

var N: integer; X: real;
s: string;
r: integer;

0 или номер неверного символа

Преобразования «строка» – «число» Из строки в число:s:= '123';Val(s, N, r); { N = 123 }s:= '123.456';Val(s,

Слайд 79Задачи
«A»: Напишите программу, которая вычисляет сумму трех чисел, введенную в

форме символьной строки. Все числа целые.
Пример:
Введите выражение:
12+3+45
Ответ: 60
«B»: Напишите программу,

которая вычисляет выражение, состоящее из трех чисел и двух знаков (допускаются только знаки «+» или «–»). Выражение вводится как символьная строка, все числа целые.
Пример:
Введите выражение:
12-3+45
Ответ: 54
Задачи«A»: Напишите программу, которая вычисляет сумму трех чисел, введенную в форме символьной строки. Все числа целые.Пример:Введите выражение:12+3+45Ответ:

Слайд 80Задачи
«C»: Напишите программу, которая вычисляет выражение, состоящее из трех чисел

и двух знаков (допускаются знаки «+», «–», «*» и «/»).

Выражение вводится как символьная строка, все числа целые. Операция «/» выполняется как целочисленное деление (div).
Пример:
Введите выражение:
12*3+45
Ответ: 81
Задачи«C»: Напишите программу, которая вычисляет выражение, состоящее из трех чисел и двух знаков (допускаются знаки «+», «–»,

Слайд 81Задачи
«D»: Напишите программу, которая вычисляет выражение, состоящее из трех чисел

и двух знаков (допускаются знаки «+», «–», «*» и «/»)

и круглых скобок. Выражение вводится как символьная строка, все числа целые. Операция «/» выполняется как целочисленное деление (div).
Пример:
Введите выражение:
2*(3+45)+4
Ответ: 100
Задачи«D»: Напишите программу, которая вычисляет выражение, состоящее из трех чисел и двух знаков (допускаются знаки «+», «–»,

Слайд 82Строки в процедурах и функциях
Задача: построить процедуру, которая заменяет в

строке s все вхождения слова-образца wOld на слово-замену wNew.
пока {

слово wOld есть в строке s }
{ удалить слово wOld из строки }
{ вставить на это место слово wNew }

wOld: '12'
wNew: 'A12B'

зацикливание

Строки в процедурах и функцияхЗадача: построить процедуру, которая заменяет в строке s все вхождения слова-образца wOld на

Слайд 83Замена всех экземпляров подстроки

Замена всех экземпляров подстроки

Слайд 84Замена всех экземпляров подстроки
program Replace;
var s: string;
... { здесь будет

процедура }
begin
s:= '12.12.12';
replaceAll(s, '12', 'A12B');
writeln(s)
end;

Замена всех экземпляров подстрокиprogram Replace;var s: string;... { здесь будет процедура }begin s:= '12.12.12'; replaceAll(s, '12', 'A12B');

Слайд 85Замена всех экземпляров подстроки
procedure replaceAll(var s: string; wOld, wNew: string);
var

res: string;
p, len: integer;
begin
len:= Length(wOld);
res:= '';

while Length(s) > 0 do begin
p:= Pos(wOld, s);
if p < 0 then begin res:= res + s; Exit; end;
if p > 1 then res:= res + Copy(s,1,p-1);
res:= res + wNew;
if p+len > Length(s) then
s:= ''
else s:= Copy(s,p+len,Length(s));
end;
s:= res
end;

найти слово wOld

не нашли…

добавить то, что перед ним

добавить wNew

взять «хвост»

Замена всех экземпляров подстрокиprocedure replaceAll(var s: string; wOld, wNew: string);var res: string;  p, len: integer;begin len:=

Слайд 86Замена: из процедуры в функцию
program Replace;
var s: string;






begin
s:= '12.12.12';

s:= replaceAll(s, '12', 'A12B');
writeln(s)
end;
function replaceAll(s,

wOld, wNew: string): string;
...
begin
... { тело процедуры }
replaceAll:= res
end;
Замена: из процедуры в функциюprogram Replace;var s: string;begin s:= '12.12.12'; s:= replaceAll(s, '12', 'A12B'); writeln(s)end;function replaceAll(s,

Слайд 87Задачи
«A»: Напишите функцию, которая возвращает первое слово переданной ей символьной

строки.
Пример:
Введите строку: Однажды в студёную зимнюю пору...
Первое слово: Однажды

Задачи«A»: Напишите функцию, которая возвращает первое слово переданной ей символьной строки. Пример:Введите строку: Однажды в студёную зимнюю

Слайд 88Задачи
«B»: Напишите функцию, которая заменяет расширение файла на заданное новое

расширение.
Пример:
Введите имя файла: qq
Введите новое расширение: tmp
Результат: qq.tmp
Пример:
Введите имя

файла: qq.exe
Введите новое расширение: tmp
Результат: qq.tmp
Пример:
Введите имя файла: qq.work.xml
Введите новое расширение: tmp
Результат: qq.work.tmp

Задачи«B»: Напишите функцию, которая заменяет расширение файла на заданное новое расширение. Пример:Введите имя файла: qqВведите новое расширение:

Слайд 89Задачи
«C»: Напишите функцию, которая заменяет во всей строке все римские

числа на соответствующие десятичные числа.
Пример:
Введите строку:
В MMXIII году в

школе CXXIII состоялся очередной выпуск XI классов.
Результат:
В 2013 году в школе 123 состоялся очередной выпуск 11-х классов.
Задачи«C»: Напишите функцию, которая заменяет во всей строке все римские числа на соответствующие десятичные числа. Пример:Введите строку:В

Слайд 90Рекурсивный перебор
Задача. В алфавите языке племени «тумба-юмба» четыре буквы: «Ы»,

«Ш», «Ч» и «О». Нужно вывести на экран все слова,

состоящие из K букв, которые можно построить из букв этого алфавита.

перебор K-1 символов

задача для слов длины К сведена к задаче для слов длины К-1!

Рекурсивный переборЗадача. В алфавите языке племени «тумба-юмба» четыре буквы: «Ы», «Ш», «Ч» и «О». Нужно вывести на

Слайд 91Рекурсивный перебор
Перебор К символов
var w: string;
begin
w[1]:='Ы';
{ перебор

последних K-1 символов }
w[1]:='Ш';
{ перебор последних K-1

символов }
w[1]:='Ч';
{ перебор последних K-1 символов }
w[1]:='О';
{ перебор последних K-1 символов }
end;
Рекурсивный переборПеребор К символовvar w: string;begin w[1]:='Ы';  { перебор последних K-1 символов } w[1]:='Ш';  {

Слайд 92Рекурсивный перебор
program YSCHO;
var word: string;












begin
word:= '...';
TumbaWords('ЫШЧО', word, 0);
end.
procedure

TumbaWords(A, w: string; N: integer);
var i: integer;
begin
if N =

Length(w) then begin
writeln(w);
exit;
end;
for i:=1 to Length(A) do begin
w[N+1]:= A[i];
TumbaWords(A, w, N+1);
end;
end;

уже установлено

когда все символы уже установлены

по всем символам алфавита

алфавит

слово

Рекурсивный переборprogram YSCHO;var word: string;begin word:= '...'; TumbaWords('ЫШЧО', word, 0);end.procedure TumbaWords(A, w: string; N: integer);var i: integer;begin

Слайд 93Задачи
«A»: В алфавите языке племени «тумба-юмба» четыре буквы: «Ы», «Ш»,

«Ч» и «О». Нужно вывести на экран все возможные слова,

состоящие из K букв, в которых вторая буква «Ы». Подсчитайте количество таких слов.

«B»: В алфавите языке племени «тумба-юмба» четыре буквы: «Ы», «Ш», «Ч» и «О». Нужно вывести на экран все возможные слова, состоящие из K букв, в которых есть по крайней мере две одинаковые буквы, стоящие рядом. Подсчитайте количество таких слов. Программа не должна строить другие слова, не соответствующие условию.

Задачи«A»: В алфавите языке племени «тумба-юмба» четыре буквы: «Ы», «Ш», «Ч» и «О». Нужно вывести на экран

Слайд 94Задачи
«C»: В алфавите языке племени «тумба-юмба» четыре буквы: «Ы», «Ш»,

«Ч» и «О». Нужно вывести на экран все возможные слова,

состоящие из K букв, в которых есть по крайней мере две одинаковые буквы, не обязательно стоящие рядом. Программа не должна строить другие слова, не соответствующие условию.
Задачи«C»: В алфавите языке племени «тумба-юмба» четыре буквы: «Ы», «Ш», «Ч» и «О». Нужно вывести на экран

Слайд 95Сравнение строк
Сравнение по кодам символов:

Сравнение строкСравнение по кодам символов:

Слайд 96Сравнение строк
5STEAM 

Сравнение строк5STEAM 

Слайд 97Сортировка строк
const N = 10;
var i,j: integer;
s1: string;

S: array[1..N] of string;
begin
for i:= 1 to

N do
readln(S[i]);







for i:= 1 to N do
writeln(S[i]);
end.

for i:= 1 to N-1 do
for j:= N-1 downto i do
if S[j+1] < S[j] then begin
s1:= S[j];
S[j]:= S[j+1];
S[j+1]:= s1;
end;

массив строк

Сортировка строкconst N = 10;var i,j: integer;  s1: string;  S: array[1..N] of string; begin for

Слайд 98Задачи
«A»: Вводится 5 строк, в которых сначала записан порядковый номер

строки с точкой, а затем – слово. Вывести слова в

алфавитном порядке.
Пример:
Введите 5 строк:
1. тепловоз
2. арбуз
3. бурундук
4. кефир
5. урядник
Список слов в алфавитном порядке:
арбуз, бурундук, кефир, тепловоз, урядник
Задачи«A»: Вводится 5 строк, в которых сначала записан порядковый номер строки с точкой, а затем – слово.

Слайд 99Задачи
«B»: Вводится несколько строк (не более 20), в которых сначала

записан порядковый номер строки с точкой, а затем – слово.

Ввод заканчивается пустой строкой. Вывести введённые слова в алфавитном порядке.
Пример:
Введите слова:
1. тепловоз
2. арбуз
 
Список слов в алфавитном порядке:
арбуз, тепловоз
Задачи«B»: Вводится несколько строк (не более 20), в которых сначала записан порядковый номер строки с точкой, а

Слайд 100Задачи
«C»: Вводится несколько строк (не более 20), в которых сначала

записаны инициалы и фамилии работников фирмы. Ввод заканчивается пустой строкой.

Отсортировать строки в алфавитном порядке по фамилии.
Пример:
Введите ФИО:
А.Г. Урядников
Б.В. Тепловозов
В.Д. Арбузов
 
Список в алфавитном порядке:
В.Д. Арбузов
Б.В. Тепловозов
А.Г. Урядников
Задачи«C»: Вводится несколько строк (не более 20), в которых сначала записаны инициалы и фамилии работников фирмы. Ввод

Слайд 101Программирование на языке Паскаль
§ 67. Матрицы

Программирование на языке Паскаль§ 67. Матрицы

Слайд 102Что такое матрица?
Матрица — это прямоугольная таблица, составленная из элементов

одного типа (чисел, строк и т.д.). Каждый элемент матрицы имеет

два индекса – номера строки и столбца.

нет знака

нолик

крестик

строка 2, столбец 3

Что такое матрица?Матрица — это прямоугольная таблица, составленная из элементов одного типа (чисел, строк и т.д.). Каждый

Слайд 103Объявление матриц
const N = 3; M = 4;
var A: array[1..N,

1..M] of integer;
X: array[-3..0, -8..M] of double;

L: array[1..N, 0..1] of boolean;

строки

столбцы

строки

столбцы

Объявление матрицconst N = 3; M = 4;var A: array[1..N, 1..M] of integer;  X: array[-3..0, -8..M]

Слайд 104Простые алгоритмы
Заполнение случайными числами:
for i:=1 to N do begin
for

j:=1 to M do begin
A[i,j]:= random(61) + 20;

write(A[i,j]:3)
end;
writeln
end;

Суммирование:

s:= 0;
for i:=1 to N do
for j:=1 to M do
s:= s + A[i,j];

Простые алгоритмыЗаполнение случайными числами:for i:=1 to N do begin for j:=1 to M do begin  A[i,j]:=

Слайд 105Задачи
«A»: Напишите программу, которая заполняет квадратную матрицу случайными числами в

интервале [10,99], и находит максимальный и минимальный элементы в матрице

и их индексы.
Пример:
Матрица А:
12 14 67 45
32 87 45 63
69 45 14 11
40 12 35 15
Максимальный элемент A[2,2]=87
Минимальный элемент A[3,4]=11
Задачи«A»: Напишите программу, которая заполняет квадратную матрицу случайными числами в интервале [10,99], и находит максимальный и минимальный

Слайд 106Задачи
«B»: Яркости пикселей рисунка закодированы числами от 0 до 255

в виде матрицы. Преобразовать рисунок в черно-белый по следующему алгоритму:
вычислить

среднюю яркость пикселей по всему рисунку
все пиксели, яркость которых меньше средней, сделать черными (записать код 0), а остальные – белыми (код 255)
Пример:
Матрица А:
12 14 67 45
32 87 45 63
69 45 14 11
40 12 35 15
Средняя яркость 37.88
Результат:
0 0 255 255
0 255 0 255
255 255 0 0
255 0 0 0
Задачи«B»: Яркости пикселей рисунка закодированы числами от 0 до 255 в виде матрицы. Преобразовать рисунок в черно-белый

Слайд 107Задачи
«С»: Заполните матрицу, содержащую N строк и M столбцов, натуральными

числами по спирали и змейкой, как на рисунках:

Задачи«С»: Заполните матрицу, содержащую N строк и M столбцов, натуральными числами по спирали и змейкой, как на

Слайд 108Перебор элементов матрицы
Главная диагональ:
for i:= 1 to N do begin

{ работаем с  A[i,i] }
end;
Побочная диагональ:
for i:= 1 to N

do begin
{ работаем с  A[i,N+1-i] }
end;

Главная диагональ и под ней:

for i:= 1 to N do
for j:= 1 to i do begin
{ работаем с  A[i,j] }
end;

Перебор элементов матрицыГлавная диагональ:for i:= 1 to N do begin { работаем с  A[i,i] }end;Побочная диагональ:for i:=

Слайд 109Перестановка строк
2-я и 4-я строки:
for j:= 1 to M do

c:= A[2,j];
A[2,j]:= A[4,j];
A[4,j]:= c
end;

Перестановка строк2-я и 4-я строки:for j:= 1 to M do c:= A[2,j]; A[2,j]:= A[4,j]; A[4,j]:= cend;

Слайд 110Задачи
«A»: Напишите программу, которая заполняет квадратную матрицу случайными числами в

интервале [10,99], а затем записывает нули во все элементы выше

главной диагонали. Алгоритм не должен изменяться при изменении размеров матрицы.
Пример:
Матрица А:
12 14 67 45
32 87 45 63
69 45 14 30
40 12 35 65
Результат:
12 0 0 0
32 87 0 0
69 45 14 0
40 12 35 65
Задачи«A»: Напишите программу, которая заполняет квадратную матрицу случайными числами в интервале [10,99], а затем записывает нули во

Слайд 111Задачи
«B»: Пиксели рисунка закодированы числами (обозначающими цвет) в виде матрицы,

содержащей N строк и M столбцов. Выполните отражение рисунка сверху

вниз:

«С»: Пиксели рисунка закодированы числами (обозначающими цвет) в виде матрицы, содержащей N строк и M столбцов. Выполните поворот рисунка вправо на 90 градусов:

Задачи«B»: Пиксели рисунка закодированы числами (обозначающими цвет) в виде матрицы, содержащей N строк и M столбцов. Выполните

Слайд 112Программирование на языке Паскаль
§ 68. Работа с файлами

Программирование на языке Паскаль§ 68. Работа с файлами

Слайд 113Как работать с файлами?
файлы
текстовые
двоичные
«plain text»:
текст, разбитый на строки;
из специальных

символов только символы перехода на новую строку
любые символы
рисунки, звуки, видео,


Как работать с файлами?файлытекстовыедвоичные«plain text»: текст, разбитый на строки;из специальных символов только символы перехода на новую строкулюбые

Слайд 114Принцип сэндвича
var Fin, Fout: Text;
Assign(Fin, 'input.txt');
Assign(Fout, 'output.txt');
Reset(Fin); { открыть

на чтение }
Rewrite(Fout); { открыть на запись }
{

здесь работаем с файлами }
Close(Fout); { закрыть файлы }
Close(Fin);

файловые переменные

связать с файлами

хлеб

хлеб

начинка

Принцип сэндвичаvar Fin, Fout: Text;Assign(Fin, 'input.txt');Assign(Fout, 'output.txt');Reset(Fin);  { открыть на чтение }Rewrite(Fout); { открыть на запись

Слайд 115Ввод данных
var a, b: integer;
Fin: Text;
...
Assign(Fin, 'input.txt');
Reset(Fin);

Close(Fin);
Close(Fin);
Reset(Fin);
readln(Fin,

a, b);
Переход к началу открытого файла:
if Eof(Fin) then { end

of file }
write('Данные кончились');

Определение конца файла:

Ввод данныхvar a, b: integer;  Fin: Text;...Assign(Fin, 'input.txt');Reset(Fin);Close(Fin); Close(Fin);Reset(Fin);readln(Fin, a, b);Переход к началу открытого файла:if Eof(Fin)

Слайд 116Вывод данных в файл
var a, b: integer;
Fout: Text;
...
a:=

1; b:= 2;
Assign(Fout,'output.txt');
Rewrite(Fout);

Close(Fout);
writeln(Fout, a, '+', b, '=', a+b);

Вывод данных в файлvar a, b: integer;  Fout: Text;...a:= 1; b:= 2;Assign(Fout,'output.txt');Rewrite(Fout);Close(Fout);writeln(Fout, a, '+', b, '=',

Слайд 117Чтение неизвестного количества данных
while { не конец файла } do

begin
{ прочитать число из файла }
{ добавить его

к сумме }
end;

Задача. В файле записано в столбик неизвестное количество чисел. Найти их сумму.

var x, S: integer;
Fin: Text;
...
Assign(Fin,'input.txt');
Reset(Fin);
S:= 0;
while not Eof(Fin) do begin
readln(Fin, x);
S:= S + x;
end;
Close(Fin);

Чтение неизвестного количества данныхwhile { не конец файла } do begin { прочитать число из файла }

Слайд 118Задачи
«A»: Напишите программу, которая находит среднее арифметическое всех чисел, записанных

в файле в столбик, и выводит результат в другой файл.

«B»:

Напишите программу, которая находит минимальное и максимальное среди чётных положительных чисел, записанных в файле, и выводит результат в другой файл. Учтите, что таких чисел может вообще не быть.

«C»: В файле в столбик записаны целые числа, сколько их – неизвестно. Напишите программу, которая определяет длину самой длинной цепочки идущих подряд одинаковых чисел и выводит результат в другой файл.

Задачи«A»: Напишите программу, которая находит среднее арифметическое всех чисел, записанных в файле в столбик, и выводит результат

Слайд 119Обработка массивов
Задача. В файле записано не более 100 целых чисел.

Вывести в другой текстовый файл те же числа, отсортированные в

порядке возрастания.

const MAX = 100;
var A: array[1..MAX] of integer;

Обработка массивовЗадача. В файле записано не более 100 целых чисел. Вывести в другой текстовый файл те же

Слайд 120Обработка массивов
Ввод массива:
var N: integer;
Fin: Text;
...
Assign(Fin,'input.txt');
Reset(Fin);
N:= 0;
while (not

Eof(Fin)) and do
begin
N:= N

+ 1;
readln(Fin, A[N]);
end;
Close(Fin);


(N < MAX)

счётчик прочитанных данных

Обработка массивовВвод массива:var N: integer;  Fin: Text;...Assign(Fin,'input.txt');Reset(Fin);N:= 0;while (not Eof(Fin)) and     do

Слайд 121Обработка массивов
Вывод результата:
var Fout: Text;
...
Assign(Fout, 'output.txt');
Rewrite(Fout);
for i:= 1 to

do
writeln(Fout, A[i]);
Close(Fout);

N

Обработка массивовВывод результата:var Fout: Text;...Assign(Fout, 'output.txt');Rewrite(Fout);for i:= 1 to  do  writeln(Fout, A[i]);   Close(Fout);N

Слайд 122Задачи
«A»: В файле записано не более 100 чисел. Отсортировать их

по возрастанию последней цифры и записать в другой файл.

«B»: В

файле записано не более 100 чисел. Отсортировать их по возрастанию суммы цифр и записать в другой файл. Используйте функцию, которая вычисляет сумму цифр числа.

«C»: В двух файлах записаны отсортированные по возрастанию массивы неизвестной длины. Объединить их и записать результат в третий файл. Полученный массив также должен быть отсортирован по возрастанию.

Задачи«A»: В файле записано не более 100 чисел. Отсортировать их по возрастанию последней цифры и записать в

Слайд 123Обработка строк
Задача. В файле записано данные о собаках: в каждой

строчке кличка собаки, ее возраст и порода:
Мухтар 4 немецкая овчарка


Вывести в другой файл сведения о собаках, которым меньше 5 лет.

пока { не конец файла }
{ прочитать строку из файла }
{ разобрать строку – выделить возраст }
если возраст < 5 то
{ записать строку в файл Fout }

Обработка строкЗадача. В файле записано данные о собаках: в каждой строчке кличка собаки, ее возраст и порода:Мухтар

Слайд 124Обработка строк
{ найти в строке пробел }
{ удалить из строки

кличку с первым пробелом }
{ найти в строке пробел }
{

выделить возраст перед пробелом }
{ преобразовать возраст в числовой вид }

Разбор строки:

var s, sAge: string;
age, p, r: integer;
... { s = 'Мухтар 4 овчарка' }
p:= Pos(' ', s); { 'Мухтар 4 овчарка' }
Delete(s, 1, p); { s = '4 овчарка' }
p:= Pos(' ', s); { '4 овчарка' }
sAge:= Copy(s, 1, p-1); { sAge = '4' }
Val(sAge, age, r); { age = 4 }

Обработка строк{ найти в строке пробел }{ удалить из строки кличку с первым пробелом }{ найти в

Слайд 125Обработка строк
var s, s0: string;
...
while not Eof(Fin) do begin

readln(Fin, s0);
s:= s0;
{ обработка строки s

}
if age < 5 then
writeln(Fout, s0);
end;
Обработка строкvar s, s0: string;...while not Eof(Fin) do begin  readln(Fin, s0);  s:= s0;  {

Слайд 126Задачи
«A»: В файле записаны данные о результатах сдачи экзамена. Каждая

строка содержит фамилию, имя и количество баллов, разделенные пробелами:

<Количество баллов>
Вывести в другой файл фамилии и имена тех учеников, которые получили больше 80 баллов.

«B»: В предыдущей задаче добавить к полученному списку нумерацию, сократить имя до одной буквы и поставить перед фамилией:
П. Иванов
И. Петров
...
Задачи«A»: В файле записаны данные о результатах сдачи экзамена. Каждая строка содержит фамилию, имя и количество баллов,

Слайд 127Задачи
«C»: В файле записаны данные о результатах сдачи экзамена. Каждая

строка содержит фамилию, имя и количество баллов, разделенные пробелами:

<Количество баллов>
Вывести в другой файл данные учеников, которые получили больше 80 баллов. Список должен быть отсортирован по убыванию балла. Формат выходных данных:
П. Иванов 98
И. Петров 96
...
Задачи«C»: В файле записаны данные о результатах сдачи экзамена. Каждая строка содержит фамилию, имя и количество баллов,

Слайд 128Конец фильма
ПОЛЯКОВ Константин Юрьевич
д.т.н., учитель информатики
ГБОУ СОШ № 163, г.

Санкт-Петербург
kpolyakov@mail.ru
ЕРЕМИН Евгений Александрович
к.ф.-м.н., доцент кафедры мультимедийной дидактики и ИТО

ПГГПУ, г. Пермь
eremin@pspu.ac.ru
Конец фильмаПОЛЯКОВ Константин Юрьевичд.т.н., учитель информатикиГБОУ СОШ № 163, г. Санкт-Петербургkpolyakov@mail.ru ЕРЕМИН Евгений Александровичк.ф.-м.н., доцент кафедры мультимедийной

Слайд 129Источники иллюстраций
www.mcdonalds.com
иллюстрации художников издательства «Бином»
авторские материалы

Источники иллюстрацийwww.mcdonalds.com иллюстрации художников издательства «Бином»авторские материалы

Обратная связь

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

Email: Нажмите что бы посмотреть 

Что такое TheSlide.ru?

Это сайт презентации, докладов, проектов в PowerPoint. Здесь удобно  хранить и делиться своими презентациями с другими пользователями.


Для правообладателей

Яндекс.Метрика