- •Розділ 1. Основи платформи .Net
- •1.1. Основи платформи .Net
- •1.2. Загальні відомості об'єктно-орієнтованого програмування
- •1.3. Середовище Visual Studio .Net
- •1.4 Консольні додатки
- •Розділ 2. Основні поняття мови
- •2.1. Склад мови
- •2.1.1 Алфавіт і лексеми
- •2.1.2. Ідентифікатори і ключові слова
- •2.1.3. Знаки операцій і роздільники
- •2.1.4. Літерали
- •Константи в с#
- •Суфікси цілих і дійсних констант
- •Управляючі послідовності у с#
- •2.1.5. Коментарі
- •2.2. Типи даних
- •2.2.1. Класифікація типів
- •2.2.2. Типи літералів
- •2.2.3. Типи-значення і посилальні типи
- •2.2.4. Упаковка і розпаковування
- •2.3. Рекомендації по програмуванню
- •Розділ 3. Змінні, іменовані константи, операції і вирази
- •3.1. Змінні і іменовані константи
- •3.2. Операції і вирази
- •3.2.1. Перетворення вбудованих арифметичних типів-значень
- •3.2.2. Введення у виключення
- •3.2.3. Основні операції с#
- •Операнд_1 ? операнд_2 : операнд_3.
- •3.3. Лінійні програми (програмування лінійних обчислювальних процесів)
- •3.3.1. Просте введення-виведення даних
- •3.3.2. Математичні функції - клас Math
- •Розділ 4. Оператори
- •4.1. Вирази, блоки
- •4.2. Оператори розгалуження
- •4.2.1. Умовний оператор if
- •4.2.1. Умовний оператор switch
- •4.3. Оператори циклу
- •4.3.1. Цикл з передумовою while
- •4.3.2. Цикл з постумовою do
- •4.3.3. Цикл з параметром for
- •For ( ініціалізація; вираз; модифікації ) оператор;
- •4.3.4. Цикл перебору foreach
- •4.3.5. Рекомендації по вибору оператора циклу
- •4.4. Обробка виняткових ситуацій
- •4.4.1. Оператор try
- •Try блок [ блоки catch ] [ блок finally ]
- •4.4.2. Оператор throw
- •Throw [ вираз ];
- •4.4.3. Клас Exception
- •4.4.4. Оператори checked и unchecked
- •4.5. Рекомендації по програмуванню
- •Розділ 5. Класи: основні поняття
- •5.1. Привласнення і порівняння об'єктів
- •5.2. Дані: поля і константи
- •5.3. Методи
- •5.3.1. Параметри методів
- •5.3.2. Параметри-значення
- •5.3.3. Параметри-посилання
- •5.3.4. Вихідні параметри
- •5.4. Ключове слово this
- •5.5. Конструктори
- •5.6. Властивості
- •[ Атрибути ] [ специфікатори ] тип ім’я_властивості
- •[ Get код_доступа ] [ set код_доступа ]
- •5.7. Рекомендації по програмуванню
- •Розділ 6. Масиви і рядки
- •6.1. Одновимірні масиви
- •6.2. Прямокутні масиви
- •6.3. Ступінчасті масиви
- •6.4. Клас System.Array
- •6.5. Клас Random
- •6.6. Оператор foreach
- •6.7. Масиви об’єктів
- •6.8. Символи і рядки
- •6.8.1. Символи
- •6.8.2. Масиви символів
- •6.8.3. Рядки типу string
- •6.8.4. Форматування рядків
- •6.8.5. Рядки типу StringBuilder
- •6.9. Рекомендації з програмування
- •Розділ 7. Класи: подробиці
- •7.1. Перевантаження методів
- •7.2. Рекурсивні методи
- •7.3. Методи із змінною кількістю аргументів
- •7.4. Метод Main
- •7.5. Індексатори
- •7.6. Операції класу
- •7.6.1. Унарні операції
- •7.6.2. Бінарні операції
- •7.6.3. Операції перетворення типу
- •7.7. Деструктор
- •7.8. Вкладені типи
- •7.9. Рекомендації по програмуванню
- •Розділ 8. Ієрархії класів
- •8.1. Спадкоємство
- •8.2. Віртуальні методи
- •8.3. Абстрактні класи
- •8.4. Безплідні класи
- •8.5. Клас object
- •8.6. Рекомендації по програмуванню
- •Розділ 9. Інтерфейси і структурні типи
- •9.1. Синтаксис інтерфейсу
- •9.2. Реалізація інтерфейсу
- •9.3. Робота з об'єктами через інтерфейси. Операції is і as
- •9.4. Інтерфейси і спадкоємство
- •9.5. Стандартні інтерфейси .Net
- •9.5.1. Порівняння об'єктів (інтерфейс iComparable)
- •9.5.2 Сортування по різних критеріях (інтерфейс iComparer)
- •9.5.3 Перевантаження операцій відношення
- •9.5.4. Клонування об'єктів (інтерфейс iСloneable)
- •9.5.5. Перебір об'єктів (інтерфейс iEnumerable) і ітератори
- •9.6. Структури
- •9.7. Перелічення
- •9.7.1 Операції з переліченнями
- •9.7.2. Базовий клас System.Enum
- •9.8. Рекомендації по програмуванню
- •Розділ 10. Делегати, події і потоки виконання
- •10.1. Делегати
- •10.1.1. Опис делегатів
- •10.1.2. Використання делегатів
- •10.1.3. Патерн “спостерігач”
- •10.1.4. Операції
- •10.1.5. Передача делегатів в методи
- •10.1.6. Обробка виключень при виклику делегатів
- •10.3. Багатопотокові додатки
- •10.3.1. Клас Thread
- •Lock ( вираз ) блок_операторів
- •10.3.2. Асинхронні делегати
- •10.4. Рекомендації по програмуванню
- •Розділ 11. Робота з файлами
- •11.1. Потоки байтів
- •11.2. Асинхронне уведення-виведення
- •11.3. Потоки символів
- •11.4. Двійкові потоки
- •11.5. Консольне уведення-виведення
- •11.6. Робота з каталогами і файлами
- •11.7. Збереження об'єктів (серіалізація)
- •11.8. Рекомендації по програмуванню
- •Розділ 12. Збірки, бібліотеки, атрибути, директиви
- •12.2. Створення бібліотеки
- •12.3. Рефлексія
- •12.4. Атрибути
- •12.5. Простір імен
- •12.6. Директиви препроцесора
- •# Константний_вираз
- •[ #Elif константний_вираз
- •[ #Elif константний_вираз
- •Розділ 13. Структури даних, колекції і класи-прототипи
- •13.1. Абстрактні структури даних
- •13.2. Простір імен System.Collections
- •13.3. Клас ArrayList
- •13.4. Класи-прототипи
- •13.5. Створення класу-прототипу
- •13.6. Узагальнені методи
- •13.7. Часткові типи
- •13.8. Типи, що обнуляються
- •13.9. Рекомендації по програмуванню
- •Розділ 14. Додаткові засоби с#
- •14.1. Небезпечний код
- •Unsafe блок
- •14.1.1. Синтаксис вказівок
- •14.1.2. Перетворення та ініціалізація вказівок
- •14.1.3. Операції з вказівками
- •14.2. Регулярні вирази
- •14.2.1. Метасимволи
- •14.2.2. Класи бібліотеки .Net для роботи з регулярними виразами
- •14.3. Документування у форматі xml
- •Лабораторні роботи
- •Лабораторна робота 5. Одновимірні масиви
- •Лабораторна робота 6. Двовимірні масиви
- •Лабораторна робота 7. Рядки
- •Лабораторна робота 8. Класи і операції
- •Лабораторна робота 9. Спадкоємство
- •Лабораторна робота 10. Структури
- •Лабораторна робота 11. Інтерфейси і параметризовані колекції
- •Список літератури
- •Додатки Додаток 1. Специфікатори формату для рядків с#
Лабораторна робота 6. Двовимірні масиви
Теоретичний матеріал: розділ 6.
Варіант 1
Дана цілочисельна прямокутна матриця. Визначити:
кількість рядків, що не містять жодного нульового елементу;
максимальне з чисел, що зустрічаються в заданій матриці більше одного разу.
Варіант 2
Дана цілочисельна прямокутна матриця. Визначити кількість стовпців, що не містять жодного нульового елементу.
Характеристикою рядка цілочисельної матриці назвемо суму її додатних парних елементів. Переставляючи рядки заданої матриці, розташувати їх відповідно до зростання характеристик.
Варіант 3
Дана цілочисельна прямокутна матриця. Визначити:
кількість стовпців, які містять хоч би один нульовий елемент;
номер рядка, в якому знаходиться щонайдовша серія однакових елементів.
Варіант 4
Дана цілочисельна квадратна матриця. Визначити:
множину елементів в тих рядках, які не містять від’ємних елементів;
максимум серед сум елементів діагоналей, паралельних головній діагоналі матриці.
Варіант 5
Дана цілочисельна квадратна матриця. Визначити:
суму елементів в тих стовпцях, які не містять від’ємних елементів;
мінімум серед сум модулів елементів діагоналей, паралельних побічній діагоналі матриці.
Варіант 6
Дана цілочисельна прямокутна матриця. Визначити:
суму елементів в тих рядках, які містять хоч би один від’ємний елемент; номери рядків і стовпців всіх седлових точок матриці.
ПРИМІТКА
Матриця А має седловую точку Аij, якщо Аij є мінімальним елементом в i -у рядку і максимальним - в j-м стовпці.
Варіант 7
Для заданої матриці розміром 8x8 знайти такі k при яких k-й рядок збігається з k-м стовпцем.
Знайти суму елементів в тих рядках, які містять хоч би один від’ємний елемент.
Варіант 8
Характеристикою стовпця цілочисельної матриці назвемо суму модулів його від’ємних непарних елементів. Переставляючи стовпці заданої матриці, розташувати їх відповідно до зростання характеристик.
Знайти суму елементів в тих стовпцях, які містять хоч би один від’ємний елемент.
Варіант 9
Сусідами елементу Aij в матриці назвемо елементи Аkl, де i - 1< до < i + 1, j - 1 < l < j + 1, (до, j) не рівно (i, j). Операція згладжування матриці дає нову матрицю того ж розміру, кожен елемент якої виходить як середнє арифметичне наявних сусідів відповідного елементу початкової матриці. Побудувати результат згладжування заданої речової матриці розміром 10 х 10.
У згладженій матриці знайти суму модулів елементів, розташованих нижче за головну діагональ.
Варіант 10
Елемент матриці називається локальним мінімумом, якщо він строго менше всіх його сусідів (визначення сусідніх елементів див. у варіанті 9). Підрахувати кількість локальних мінімумів заданої матриці розміром 10 х 10.
Знайти суму модулів елементів, розташованих вище за головну діагональ.
Варіант 11
Коефіцієнти системи лінійних рівнянь задані у вигляді прямокутної матриці. За допомогою допустимих перетворень привести систему до трикутного вигляду.
Знайти кількість рядків, середнє арифметичне елементів яких менше заданої величини.
Варіант 12
Ущільнити задану матрицю, видаляючи з неї рядки і стовпці, заповнені нулями.
Знайти номер першою з рядків, що містять хоч би один додатний елемент.
Варіант 13
Здійснити циклічне зрушення елементів прямокутної матриці n елементів управо або вниз (залежно від введеного режиму), n може бути більше кількості елементів в рядку або стовпці.
Варіант 14
Дана цілочисельна прямокутна матриця. Визначити номер першого із стовпців, що містять хоч би один нульовий елемент.
Характеристикою рядка цілочисельної матриці назвемо суму її від’ємних парних елементів. Переставляючи рядки заданої матриці, розташувати їх відповідно до убування характеристик.
Варіант 15
Упорядкувати рядки цілочисельної прямокутної матриці за збільшенням кількості однакових елементів в кожному рядку.
Знайти номер першого із стовпців, що не містять жодного від’ємного елементу.
Варіант 16
Шляхом перестановки елементів квадратної речової матриці добитися того, щоб її максимальний елемент знаходився в лівому верхньому кутку, наступний по величині - в позиції (2, 2), наступний по величині - в позиції (3, 3) і т. д., заповнивши всю головну діагональ.
Знайти номер першого з рядків, що не містить жодного додатного елементу.
Варіант 17
Дана цілочисельна прямокутна матриця. Визначити:
кількість рядків, що містять хоч би один нульовий елемент;
номер стовпця, в якому знаходиться щонайдовша серія однакових елементів.
Варіант 18
Дана цілочисельна квадратна матриця. Визначити:
суму елементів в тих рядках, які не містять від’ємних елементів;
мінімум серед сум елементів діагоналей, паралельних головній діагоналі матриці.
Варіант 19
Дана цілочисельна прямокутна матриця. Визначити:
кількість від’ємних елементів в тих рядках, які містять хоч би один нульовий елемент;
номери рядків і стовпців всіх седлових точок матриці (визначення сусідніх елементів див. у варіанті 9).
Варіант 20
Дана цілочисельна прямокутна матриця.
Упорядкувати елементи головної діагоналі.