Програмування структурованих типів даних в С++. Тема 7. Заняття 1. Масиви

Содержание

Слайд 2

Література до заняття

С++. Основи програмування. Теорія та практика : підручник / [О.Г.

Література до заняття С++. Основи програмування. Теорія та практика : підручник /
Трофименко, Ю.В. Прокоп, І.Г. Швайко, Л.М. Буката та ін.] ; за ред. О.Г. Трофименко. – Одеса: Фенікс, 2011. – 587 с.

Слайд 3

Література

Література

Слайд 4

Література

Література

Слайд 5

Література до заняття

Вступ до програмування мовою С++. Організація обчислень: навч. посіб. /

Література до заняття Вступ до програмування мовою С++. Організація обчислень: навч. посіб.
Ю. А. Бєлов, Т. О. Карнаух, Ю. В. Коваль, А. Б. Ставровський. – К. : Видавничо-поліграфічний центр "Київський університет", 2012. – 175 с.
С++. Основи програмування. Теорія та практика : підручник / [О.Г. Трофименко, Ю.В. Прокоп, І.Г. Швайко, Л.М. Буката та ін.] ; за ред. О.Г. Трофименко. – Одеса: Фенікс, 2010. – 544 с.
Глинський Я.М., Анохін В.С., Ряжська В.А. C++ і C++ Builder. Навч.посібник. 3-тє вид. –Львів: СПД Глинський, 2006. – 192 с.

Слайд 6

Масиви

Масиви – це група однотипних елементів які мають загальне ім'я і

Масиви Масиви – це група однотипних елементів які мають загальне ім'я і
розміщені в пам’яті один біля одного.
Особливості:
всі елементи мають один тип
весь масив має одне ім’я
всі елементи розміщенні в пам’яті один біля одного
Приклади:
Список курсантів в групі
Квартири в будинку
Школи в місті
Дані про температуру повітря за рік

Слайд 7

Масиви

A

масив

2

15

НОМЕР
Елемента масива
(ІНДЕКС)

A[0]

A[1]

A[2]

A[3]

A[4]

ЗНАЧЕННЯ
Елемента масива

A[2]

НОМЕР(ІНДЕКС) елемента масива: 2

ЗНАЧЕННЯ
Елемента масива: 15

Масиви A масив 2 15 НОМЕР Елемента масива (ІНДЕКС) A[0] A[1] A[2]

Слайд 8

Оголошення масивів

Навіщо оголошувати?
Визначити ім’я масива
Визначити тип масива
Визначити число елементів
Виділити місце в

Оголошення масивів Навіщо оголошувати? Визначити ім’я масива Визначити тип масива Визначити число
пам’яті
Приклад:
Розмір через константу:

Ім’я

Розмір масива
(кількість елементів)

Тип елементів
int A [ ];

const int N = 5;

N

int A [ 5 ];

Слайд 9

Оголошення масивів

Ще приклади:

int X[10], Y[10];
float zz, A[20];
char s[80];

З присвоюванням початкових значень

Оголошення масивів Ще приклади: int X[10], Y[10]; float zz, A[20]; char s[80];
:

int A[4] = { 8, -3, 4, 6 };
float B[2] = { 1. };
char C[3] = { 'A', '1', 'Ю' };

Решта нульові!

Слайд 10

Що неправильно?

int N = 10;
float A[N];

const int

int X[4.5];

int

Що неправильно? int N = 10; float A[N]; const int int X[4.5];
A[10];
A[10] = 0;

float X[5];
int n = 1;
X[n-2] = 4.5;
X[n+8] = 12.;

Виходить за рамки масива
(стираються дані в памяті)

int X[4];
X[2] = 4.5;

Дробова частина відкидається (помилки немає)

float B[2] = { 1., 3.8, 5.5 };

int A[2] = { 1, 3.8 };

float

Слайд 11

Масиви

Оголошення :
Введення з клавіатури:
Поелементні операції:
Виведення на екран:

const int N = 5;

Масиви Оголошення : Введення з клавіатури: Поелементні операції: Виведення на екран: const

int A[N], i;

cout << "Введіть 5 елементів" << endl;
for( i=0; i < N; i++ ) {
cout << " A[" << i << "]=";
cin >> a[i] >> endl;
}

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

5
12
34
56
13

for( i=0; i < N; i++ ) A[i] = A[i]*2;

cout << "Результат:" << endl;
for( i=0; i < N; i++ ) cout << A[i] << " ";
cout << endl;

Результат:
10 24 68 112 26

Слайд 12

Програма

#include
#include
main()
{
const int N = 5;
int A[N], i;
// введення елементів

Програма #include #include main() { const int N = 5; int A[N],
масива
// обробка масива
// виведення масива
getch();
}

Завдання: ввести з клавіатури масив з 5 елементів, помножити всі елементи на 2 і вивести отриманий масив на екран.

На попередніх слайдах

Слайд 13

Програмування мовою С++

Тема . Максимальний елемент масива

Програмування мовою С++ Тема . Максимальний елемент масива

Слайд 14

Максимальний елемент

Завдання: знайти в масиві максимальний елемент.
Алгоритм:

Псевдокод :

// рахуємо, що елемент

Максимальний елемент Завдання: знайти в масиві максимальний елемент. Алгоритм: Псевдокод : //
A[0] – максимальний
for ( i=1; i < N; i++ )
if ( A[i] > максимального )
// запамятати новий максимальний елемент A[i]

Слайд 15

Максимальний елемент

max = A[0]; // поки A[0]– максимальний
iMax = 0;
for (

Максимальний елемент max = A[0]; // поки A[0]– максимальний iMax = 0;
i=1; i < N; i++ ) // перевіряємо інші
if ( A[i] > max ) { // знайшли новий
max = A[i]; // запамятати A[i]
iMax = i; // запамятати i
}

Додаток : як знайти номер максимального елемента?

По номеру елементу iMax завжди можна знайти його значення A[iMax]. Тому всюди міняємо max на A[iMax] і прибераємо змінну max.

A[iMax]

Слайд 16

Заповнення випадковими числами

RAND_MAX – максимальне випадкове число (зазвичай RAND_MAX = 32767)
Ініціалізація генератору

Заповнення випадковими числами RAND_MAX – максимальне випадкове число (зазвичай RAND_MAX = 32767)
випадкових чисел
randomize(); // запуск генератору
Випадкове ціле число в інтервалі [0,RAND_MAX]
x = random(); //перше число
x = random (); // вже інше число
Встановити початкове значення послідовності :
random ( 345 ); // починоємо з 0

#include // випадкові числа

Слайд 17

Цілі числа в заданому інтервалі
Цілі числа в інтервалі [0,N-1]:
Приклади :
Цілі

Цілі числа в заданому інтервалі Цілі числа в інтервалі [0,N-1]: Приклади :
числа в інтервалі [a,b]:

int random (int N) {
return rand()% N;}

x = random ( 100 ); // інтервал[0,99]
x = random ( z ); // інтервал [0,z-1]
x = (50-random(100)); // інтервал[-49,50]
int x = RandomRange(15,20); // інтервал[15,20]

x = random ( z ) + a; // інтервал [a,z-1+a]
x = random (b – a + 1) + a; // інтервал [a,b]

Слайд 18

Заповнення випадковими числами

#include
#include
main()
{randomize();
const int N = 10;
int A[N], i;
cout <<

Заповнення випадковими числами #include #include main() {randomize(); const int N = 10;
"Початковий масив:\n";
for (i = 0; i < N; i++ ) {
A[i] = random(100) + 50;
cout << "A[i]=" << A[i]\n;
}
...
}

int random(int N)
{ return rand() % N; }

Функція видає випадкове число від 0 до N-1

Слайд 19

Програма

#include
#include
main()
{
const int N = 5;
int A[N], i, iMax;
// запамятати

Програма #include #include main() { const int N = 5; int A[N],
випадкові числа [100,150]
// знайти максимальний елемент і його номер
cout <<"\t Максимальний елемент A[" << iMax; cout << "]=" << A[iMax]\n;
getch();
}

На попередніх слайдах

Слайд 20

Програмування мовою С++

Тема . Обробка масивів

Програмування мовою С++ Тема . Обробка масивів

Слайд 21

Реверс масива

Завдання: переставити елементи масива в обернутому порядку (виконати інверсію).
Алгоритм:
Поміняти місцями A[0]

Реверс масива Завдання: переставити елементи масива в обернутому порядку (виконати інверсію). Алгоритм:
и A[N-1], A[1] и A[N-2], …
Псевдокод :

for ( i = 0; i < N; i++ )
// помінти місцями A[i] и A[N-1-i]

сума індексів N-1

Слайд 22

Як переставити елементи?

2

3

1

Завдання: поміняти місцями вміст двох чашок .

Завдання: поміняти місцями вміст

Як переставити елементи? 2 3 1 Завдання: поміняти місцями вміст двох чашок
двох чарунок памяті.

4

6

?

4

6

4

x

y

c

c = x;
x = y;
y = c;

x = y;
y = x;

3

2

1

Слайд 23

Програма

main()
{
const int N = 10;
int A[N], i, c;
// заповнити

Програма main() { const int N = 10; int A[N], i, c;
масив
// вивести початковий масив
for ( i = 0; i < N/2; i++ ) {
c = A[i];
A[i] = A[N-1-i];
A[N-1-i] = c;
}
// вивести отриманий масив
}

Слайд 24

Циклічний зсув

Завдання : зсунути елементи масива вліво на 1чарунку, перший елемент стає

Циклічний зсув Завдання : зсунути елементи масива вліво на 1чарунку, перший елемент
на місце остатнього .
Алгоритм:
A[0]=A[1]; A[1]=A[2];… A[N-2]=A[N-1];
Цикл:

for ( i = 0; i < N-1; i ++) A[i] = A[i+1];

Чому не N?

Слайд 25

Програма

main()
{
const int N = 10;
int A[N], i, c;
// заповнити

Програма main() { const int N = 10; int A[N], i, c;
масив
// вивести початковій масив
c = A[0];
for ( i = 0; i < N-1; i ++)
A[i] = A[i+1];
A[N-1] = c;
// вивести новий масив
}

Слайд 26

Програмування мовою С++

Тема. Сортування масивів

Програмування мовою С++ Тема. Сортування масивів

Слайд 27

Сортування

Сортування це розстановка елементів масива в заданому порядку (по збільшенню, зменшенню..)
Задача

Сортування Сортування це розстановка елементів масива в заданому порядку (по збільшенню, зменшенню..)
: переставити елементи масива в порядку збільшення .
Алгоритми :
Прості й зрозумілі але не ефективні для великих масивів
Метод бульбашки
Метод вибора
Складні але ефективні
«швидке сортування» (Quick Sort)
сортування «кучею» (Heap Sort)
сортування злиттям
пірамідальне сортування

складність O(N2)

складністьO(N·logN)

Слайд 28

Метод бульбашки

Ідея – бульбашка в стакані з водою з дна піднімається вверх

Метод бульбашки Ідея – бульбашка в стакані з водою з дна піднімається
.
Для масивів – самий маленький («легкий ») елемент переміщається вверх («в спливає»).

Починається знизу, порівнюємо два сусідніх елемента; якщо вони стоять «неправильно», міняємо їх місцями
Через 1 прохід по масиву один елемент (самий маленький) стає на своє місце

1-ший прохід

2-й прохід

3-й прохід

Для сортування масива із N елементів потрібен N-1 прохід (достатньо поставити на своє місце N-1 елементів).

Слайд 29

Програма (1-ий прохід)

Порівнюються пари
A[N-2] та A[N-1],
A[N-3] та A[N-2]

Програма (1-ий прохід) Порівнюються пари A[N-2] та A[N-1], A[N-3] та A[N-2] …

A[0] та A[1]

A[j] та A[j+1]

for( j = N-2; j >= 0 ; j-- )
if ( A[j] > A[j+1] ) {
c = A[j];
A[j] = A[j+1];
A[j+1] = c;
}

0

Слайд 30

Програма (наступні проходи)

2-ий прохід

for ( j = N-2; j >= 1 ;

Програма (наступні проходи) 2-ий прохід for ( j = N-2; j >=
j-- )
if ( A[j] > A[j+1] ) {
c = A[j];
A[j] = A[j+1];
A[j+1] = c;
}

1

(i+1)-ий прохід

for ( j = N-2; j >= i ; j-- )
...

i

Слайд 31

Програма

main()
{
const int N = 10;
int A[N], i, j, c;
//

Програма main() { const int N = 10; int A[N], i, j,
заповнити масив
// вивести початковий масив
for (i = 0; i < N-1; i ++){
for (j = N-2; j >= i ; j --)
if ( A[j] > A[j+1] ) {
с = A[j];
A[j] = A[j+1];
A[j+1] = с;
}
}
// вивести новий масив
}

Елементи вище A[i] вже поставлені

i

Міняємо A[j] та A[j+1]

Слайд 32

Метод бульбашки з прапорцем

Ідея – якщо при виконанні метода бульбашки не було

Метод бульбашки з прапорцем Ідея – якщо при виконанні метода бульбашки не
обмінів, масив вже відсортований і решта проходів непотрібні.
Реалізація: змінна-прапорець, вказуюча, чи був обмін; якщо вона дорівнює 0, тоді вихід.

do {
flag = 0; // скинути прапорець
for (j = N-2; j >= 0; j --)
if ( A[j] > A[j+1] ) {
с = A[j];
A[j] = A[j+1];
A[j+1] = с;
flag = 1; // підняти прапорець
}
}
while ( flag ); // вихід якщо flag = 0

flag = 0;

flag = 1;

( flag );

int flag;

Слайд 33

Метод бульбашки з прапорцем

i = 0;
do {
flag = 0; // скинути

Метод бульбашки з прапорцем i = 0; do { flag = 0;
прапорець
for ( j = N-2; j >= i ; j -- )
if ( A[j] > A[j+1] ) {
с = A[j];
A[j] = A[j+1];
A[j+1] = с;
flag = 1; // підняти прапорець
}
i ++;
}
while ( flag ); // вихід якщо flag = 0

i = 0;

i

i ++;

Слайд 34

Метод вибірки

Ідея :
Знайти мінімальний елемент і поставити його на місце(поміняти місцями

Метод вибірки Ідея : Знайти мінімальний елемент і поставити його на місце(поміняти
з A[0])
Із решти елементів знайти мінімальний і поставити його на друге місце (поміняти місцями з A[1]), і т.д.

Слайд 35

Метод вибірки

N

for( i = 0; i < N-1 ; i ++

Метод вибірки N for( i = 0; i nMin = i ;
) {
nMin = i ;
for ( j = i+1; j < N; j ++)
if( A[j] < A[nMin] ) nMin = j;
if( nMin != i ) {
c = A[i];
A[i] = A[nMin];
A[nMin] = c;
}
}

N-1

Потрібно N-1 проходів

Пошук мінімального від A[i] до A[N-1]

Якщо потрібно, переставляємо

i+1

i

Слайд 36

Формування масиву за умовою

Завдання – знайти в масиві елементи які задовільняють деяку

Формування масиву за умовою Завдання – знайти в масиві елементи які задовільняють
умову (наприклад, від'ємні), і скопіювати в інший масив.

Елементарне рішення:

const int N = 5;
int A[N], B[N];
// тут заповнити масив A
for( i = 0; i < N; i ++ )
if( A[i] < 0 ) B[i] = A[i];

A

B

Вибрані елементи не поруч, не в початку масива
Незрозуміло як з ними працювати

Слайд 37

Формування масиву за умовою

Рішення: ввести лічильник знайдених елементів count, наступний елемент ставиться

Формування масиву за умовою Рішення: ввести лічильник знайдених елементів count, наступний елемент
на місце B[count].

int A[N], B[N], count = 0;
// тут заповнюється масив A
for( i = 0; i < N; i ++ )
if( A[i] < 0 ) {
B[count] = A[i];
count ++;
}
// вивід масива B
for( i = 0; i < count; i ++ )
printf("%d\n", B[i]);

A

B

count

Слайд 38

Програмування мовою С++

Тема. Пошук в масиві

Програмування мовою С++ Тема. Пошук в масиві

Слайд 39

Пошук в масиві

Завдання – знайти в масиві елемент, рівний X, або встановити,

Пошук в масиві Завдання – знайти в масиві елемент, рівний X, або
що він відсутній.
Рішення: для довільного масиву: лінійний пошук
недолік: низька швидкість
Як прискорити? – завчасно підготовити масив до пошуку
Як саме підготувати?
Як використовувати «підготовлений» масив?

Слайд 40

Лінійний пошук

nX = -1;
for ( i = 0; i < N; i

Лінійний пошук nX = -1; for ( i = 0; i if
++)
if ( A[i] == X ) {
nX = i;
break; //вихід з циклу
}


Поліпшення: після того як знайшли X, виходимо з циклу.

break;

nX = -1; // доки не знайшли...
for ( i = 0; i < N; i ++) // цикл по всім елементам
if ( A[i] == X ) // якщо знайшли, тоді...
nX = i; // ...запам'ятовуємо номер
if (nX < 0) cout << "Не знайшли... "/n;
else cout << "A[" << nX << "]=" << X/n;

nX – номер потрібного елемента в масиві

Слайд 41

Двійковий пошук

X = 7

X < 8

8

4

X > 4

6

X > 6

Вибираємо середній елемент

Двійковий пошук X = 7 X 8 4 X > 4 6
A[c] і порівнюємо з X.
Якщо X = A[c], знайшли (вихід).
Якщо X < A[c], шукати дальше в першій половині.
Якщо X > A[c], шукати дальше в другій половині.

Слайд 42

Двійковий пошук

N-1

nX = -1;
L = 0; R = N-1;

Двійковий пошук N-1 nX = -1; L = 0; R = N-1;
// границі : від A[0] до A[N-1]
while ( R >= L ){
c = (R + L) / 2;
if (X = = A[c]) {
nX = c;
break;
}
if (X < A[c]) R = c - 1;
if (X > A[c]) L = c + 1;
}
if (nX < 0) cout << "Не знайшли... "/n;
else cout << "A[" << nX << "]=" << X/n;

Номер середнього елемента

Якщо знайшли…

Вийти із циклу

Здвигаємо границі

>

Имя файла: Програмування-структурованих-типів-даних-в-С++.-Тема-7.-Заняття-1.-Масиви.pptx
Количество просмотров: 47
Количество скачиваний: 0