- •Міністерство освіти і науки україни
- •Розділ 1. Арифметичні основи обчислювальних машин
- •1.1. Позиційні системи числення. Переведення числа з однієї системи числення в іншу
- •1.2. Форма представлення чисел. Кодування чисел
- •1.3. Арифметичні операції над двійковими числами. Машинні одиниці інформації
- •Контрольні питання
- •Завдання
- •Розділ 2. Основи алгоритмізації обчислювальних процесів
- •2.1. Поняття і властивості алгоритму
- •2.2. Засоби представлення алгоритмів
- •2.3. Типи алгоритмічних процесів. Приклади
- •Контрольні питання
- •Завдання
- •3.1. Загальна характеристика програми
- •3.3. Кроки для створення та виконання програми
- •3.4. Змінні та константи
- •3.5. Директиви препроцесора
- •Контрольні питання
- •Розділ 4. Введення-виведення даних
- •4.1. Об’єкт виведення даних cout
- •4.2. Функція виведення даних printf
- •4.3. Об’єкт введення даних cin
- •4.4. Функція введення даних scanf
- •Контрольні питання
- •5.2. Операції відношення
- •5.3. Логічні операції
- •5.4. Додаткові операції
- •5.5. Порозрядні операції
- •Контрольні питання
- •Завдання Лінійний обчислювальний процес
- •1. Визначити значення функції y
- •2. Геометричні завдання
- •Розгалужений обчислювальний процес
- •1. Визначити значення функції y
- •3. Перевірити, чи міститься точка з заданими координатами усередині заштрихованої області.
- •Розділ 6. Організація циклів
- •6.1. Організація арифметичних циклів з використанням оператору for
- •6.2. Організація ітераційних циклів з передумовою while та післяумовою do...While
- •6.3. Оператори switch та goto
- •Контрольні питання
- •Завдання Арифметичний цикл
- •Вкладені цикли
- •Ітераційний цикл
- •Суміщення розгалуженого та циклічного процесів
- •Розділ 7. Зовнішні пристрої та символьне введення/виведення. Рядкові, числові функції та функції роботи з датою та часом
- •7.1. Загальна концепція та функції символьного введення-виведення
- •7.2. Символьні функції
- •7.3. Рядкові функції
- •7.4. Числові функції
- •7.5. Функції роботи з датою та часом
- •Контрольні питання
- •Завдання
- •Розділ 8. Вказівки, посилання та масиви
- •8.1. Вказівки
- •8.2. Посилання
- •8.3. Одновимірні масиви
- •8.4. Багатовимірні масиви
- •8.5. Символьні масиви
- •Контрольні питання
- •Завдання Одновимірні масиви
- •Двовимірні масиви
- •Розділ 9. Робота з функціями
- •9.1. Засоби створення функцій
- •9.2. Видимість змінних
- •9.3. Параметри функції та передача значень
- •9.4. Передача масивів в якості параметрів функцій
- •9.5. Функції та вказівки
- •9.6. Перевантаження та шаблони функцій
- •Контрольні питання
- •Завдання
- •Розділ 10. Рекурсивне програмування
- •10.1. Основні поняття рекурсії. Визначення факторіалу числа
- •10.2. Приклади рекурсій
- •Контрольні питання
- •Розділ 11. Робота з файлами
- •11.1. Робота з текстовими та бінарними файлами
- •Можливі режими доступу
- •11.2. Довільний доступ у файлах
- •11.3. Файли потокового введення/виведення з використанням структури file.
- •Контрольні питання
- •Завдання
- •Розділ 12. Структури
- •12.1. Загальна характеристика структури
- •12.2. Масиви структур
- •12.3. Використання масивів, як елементів структур
- •3. Робота зі структурами є універсальною, передбачено додавання записів до файлу (флаг ios:app). Для підрахунку кількості структур на диску приведемо наступні рядки програми:
- •Контрольні питання
- •Завдання
- •Розділ 13. Об’єднання та інші типи даних. Обробка виключних ситуацій
- •13.1. Об’єднання
- •13.2. Перелічені типи даних (enum)
- •13.3. Бітові поля
- •13.4. Обробка виключних ситуацій
- •Контрольні питання
- •Розділ 14. Динамічні структури даних
- •14.1. Стек
- •14.2. Черга
- •14.3. Лінійний список
- •Контрольні питання
- •Завдання
- •Розділ 15. Типові методи сортування масивів
- •15.1. Бульбашкове сортування (bubble sort)
- •15.2. Сортування за допомогою вибору (choice sort)
- •15.3. Сортування вставками (insert sort)
- •15.4. Сортування Шелла
- •15.5. Швидке сортування (quick sort)
- •Контрольні питання
- •Завдання
- •Розділ 16. Чисельне диференціювання та інтегрування
- •16.1. Методи правих та центральних різниць чисельного диференціювання
- •16.2. Методи прямокутників, трапецій, Сімпсона (парабол) чисельного інтегрування
- •Контрольні питання
- •Завдання Чисельне диференціювання
- •Чисельне інтегрування
- •Розділ 17. Чисельні методи розв’язання алгебраїчних рівнянь
- •17.1. Метод половинного ділення (дихотомія)
- •17.2. Метод Ньютона (метод дотичних)
- •17.3. Метод Рибакова
- •Контрольні питання
- •Завдання
- •Розділ 18. Чисельні методи розв’язання системи лінійних алгебраїчних рівнянь
- •18.1. Визначник. Дії над матрицями. Обчислення оберненої матриці
- •18.2. Метод оберненої матриці.
- •18.3. Метод Крамера
- •18.4. Метод Гауса
- •Контрольні питання
- •Завдання
- •1. Розв’язати систему алгебраїчних рівнянь.
- •2. Обчислити добуток матриць.
- •3. Розв’язати матричні рівняння.
- •Список літератури
15.2. Сортування за допомогою вибору (choice sort)
При сортуванні за допомогою вибору (сортування вибором, сортування вибірками) з масиву вибирається елемент з найменшим значенням і обмінюється з першим елементом. Потім з тих, що залишилися n - 1 елементів знову вибирається елемент з найменшим ключем і обмінюється з другим елементом, і т.д. Ці обміни продовжуються до двох останніх елементів. Наприклад, якщо застосувати метод вибору до масиву 4, 3, 1, 2, кожен прохід буде виглядати так, як показано нижче:
Початок 4 3 1 2
Прохід 1 1 3 4 2
Прохід 2 1 2 4 3
Прохід 3 1 2 3 4
Нижченаведений код демонструє просте сортування за допомогою вибору:
void ChoiceSort(double* a, int l, int r)
{
int i,j,k,exch;
double tmp;
for(i=l;i<=r;i++)
{
k=i;
exch=0;
tmp=a[i];
for(j=i+1;j<=r;j++)
{
if(a[j]<tmp)
{ k=j;tmp=a[j];exch=1;}
}
if(exch){a[k]=a[i];a[i]=tmp;}
}
}
Як і в бульбашковому сортуванні, зовнішній цикл виконується п - 1 раз, внутрішній - в середньому п/2 раз. Отже, сортування за допомогою вибору вимагає (п2 - п)/2 порівняння. Таким чином, це алгоритм порядку п2, із-за чого він вважається дуже повільним для сортування великої кількості елементів. Не дивлячись на те, що кількість порівнянь в бульбашковому сортуванні і сортуванні за допомогою вибору однакове, в останній кількість обмінів в середньому випадку набагато менше, ніж в бульбашковому сортуванні.
15.3. Сортування вставками (insert sort)
Сортування вставками – третій і останній з простих алгоритмів сортування. Спочатку він сортує два перші елементи масиву. Потім вставляється третій елемент у відповідну порядку позицію по відношенню до перших двох елементів. Після цього вставляється четвертий елемент в список з трьох елементів. Цей процес повторюється до тих пір, поки не будуть вставлені всі елементи. Наприклад, при сортуванні масив 4, 3, 1, 2 кожен прохід алгоритму виглядатиме таким чином:
Початок 4 3 1 2
Прохід 1 3 4 1 2
Прохід 2 1 3 4 2
Прохід 3 1 2 3 4
Приклад реалізації сортування вставками показаний нижче:
void InsertSort(double* a, int l, int r)
{
int i,j;
double tmp;
for(i=l+1;i<=r;i++)
{
tmp=a[i];
for(j=i-1;(j>=l) && (tmp<a[j]);j--)
a[j+1]=a[j];
a[j+1]=tmp;
}
}
На відміну від бульбашкового сортування і сортування за допомогою вибору, кількість порівнянь в сортуванні вставками залежить від початкової впорядкованості списку. Якщо список вже відсортований, кількість порівнянь дорівнює п - 1; інакше його продуктивність є величиною порядку п2.
Взагалі кажучи, в гірших випадках сортування вставками настільки ж неефективне, як бульбашкове сортування і сортування за допомогою вибору, а в середньому вона лише трохи краще. Проте, у сортуванні вставками є переваги. Його поведінка є природною. Іншими словами, воно працює менше всього, коли масив вже впорядкований, і більше всього, коли масив відсортований в зворотному порядку. Тому сортування вставками – ідеальний алгоритм для майже впорядкованих списків.
Не дивлячись на те, що кількість порівнянь при певних наборах даних може бути досить низькою, при кожній вставці елементу на своє місце масив необхідно зрушувати. Внаслідок цього кількість переміщень може бути значною.
Покращені алгоритми сортування.
Всі прості алгоритми мають один фатальний недолік – час їх виконання має порядок п2. Це робить сортування великих об’ємів даних дуже повільним. По суті, в якийсь момент ці алгоритми стають дуже повільними, щоб їх застосовувати. Тобто необхідно застосовувати кращі алгоритми сортування.
Найбільш популярні два покращені методи сортування. Перший називається сортуванням Шелла. Другий - швидке сортування - вважається найкращим алгоритмом сортування. Обидва методи є більш довершеними способами сортування і мають набагато кращу загальну продуктивність, чим будь-який з простих методів.