Об’єктно-орієнтоване програмування

Торговельний, почтовий та банківський офіс. Створення абстрактного класу Торговий який є спадкоємцем батьківського класу Офіс. Розробка алгоритму рішення задач. Алгоритм пошуку у стеку за яким оборот перевищує задане число. Програма рішення задачі.

Рубрика Программирование, компьютеры и кибернетика
Вид курсовая работа
Язык украинский
Дата добавления 30.11.2016
Размер файла 170,9 K

Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже

Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.

Размещено на http://www.allbest.ru/

Курсовий проект з дисципліни

"Об'єктно - орієнтоване програмування"

Галузь знань 0501 " Інформатика та обчислювальна техніка"

Напрям підготовки - 6.050101 "Комп'ютерні науки"

Київ

2015

Зміст

  • Вступ
  • 1. Реферативна глава (Торговельний офіс, Почтовий офіс, Банківський офіс)
  • 2. Постановка задачі
  • 3. Розробка ієрархії класів
    • 3.1 Створення абстрактного класу Офіс
    • 3.2 Створюємо клас Торговий який є спадкоємцем батьківського класу Офіс
    • 3.3 Створюємо клас Почтовий який є спадкоємцем батьківського класу Офіс
    • 3.4 Створюємо клас Банк який є спадкоємцем батьківського класу Офіс
  • 4. Розробка алгоритму рішення задач
    • 4.1 Алгоритм додавання елементу у стек і зберігання його у файлі
    • 4.2 Алгоритм для перегляду вмісту стека
    • 4.3 Алгоритм для редагування елемента у стеку
    • 4.4 Алгоритм для знищення елемента у стеку
    • 4.5 Алгоритм пошуку у стеку по точному збігу під рядка в рядку
    • 4.6 Алгоритм пошуку у стеку за яким оборот перевищує задане число
    • 4.7 Алгоритм пошуку у стеку за яким виручка перевищує задане число
    • 4.8 Алгоритм сортування у стеку за алфавітом за назвою
    • 4.9 Алгоритм сортування у стеку по зростанню за виручкою
    • 4.10 Алгоритм сортування у файлі за алфавітом
  • 5. Розробка програми рішення задачі
  • 6. Розробка керівництва користувача
  • Висновок
  • Список використаної літератури
  • Вступ
  • Курсовий проект з дисципліни "Об'єктно - орієнтоване програмування" дозволяє освоїти принципи і методи об'єктно - орієнтованого стилю програмування, а також є заключним етапом вивчення теоретичних основ і забезпечує закріплення лекційного матеріалу шляхом більш глибокого вивчення основних розділів дисципліни.
  • Основна мета курсового проектування формування навичок самостійної творчої роботи і закріплення теоретичних знань, отриманих при вивченні курсу.
  • Для вивчення та закріплення навичок в об'єктно - орієнтованому програмуванні, що є в даний час основним інструментом розробки складного програмного забезпечення в даному курсовому проекті розроблена програма, яка з використанням засобів ООП створює динамічну структуру стек у яку можна додавати об'єкти кожного з класів створеної ієрархії.
  • Курсовий проект виконував з використанням Microsoft Visual Studio 2008, під час написання придбав навички самостійної роботи над науково-технічною і довідковою літературою за фахом та іншими посібниками; самостійний вибір найбільш доцільних і технічно зроблених рішень та задач за розглянутим курсом.
  • При виконанні курсового проекту в мене з'явилась необхідність приймати обґрунтовані самостійні рішення з урахуванням призначення програми, технічних вимог до неї зв'язані з умовами експлуатації її користувачами. У ході розробки програмного забезпечення ознайомився з типовими аналогами, критично їх проаналізував і застосував окремі, найбільш раціональні рішення.
  • 1. Реферативна глава (Торговельний офіс, Почтовий офіс, Банківський офіс)
  • У платформі .NET Framework всі керовані мови, наприклад, Visual Basic і C#, повністю підтримують концепції об'єктно-орієнтованого програмування, включаючи інкапсуляцію, успадкування і поліморфізм.
  • Інкапсуляція означає, що група пов'язаних властивостей, методів та інших членів розглядається як єдиний елемент або об'єкт.
  • Спадкування описує можливість створення нових класів на основі існуючих класів.
  • Поліморфізм означає, що можна мати кілька взаємозамінних класів, навіть якщо кожен клас реалізує одні й ті ж властивості або методи різними способами. банківський батьківський офіс алгоритм
  • Класи оголошуються за допомогою ключового слова Class, як показано в наступному прикладі.
  • class Post
  • Класи, оголошені безпосередньо в просторі імен і не вкладені в інші класи, можуть бути відкритими або внутрішніми. Класи є внутрішніми, за замовчуванням.

Для членів класу (даних і методів) визначені такі модифікатори доступу:

Public - члени класу доступні за межами даного класу;

Internal - члени класу доступні в межах однієї збірки;

Protected - члени класу доступні усередині даного класу;

Private - члени класу доступні тільки для інших членів даного класу.

За замовчанням застосовується модифікатор Internal. Клас може містити оголошення наступних елементів :

Конструктори, деструктори, константи, поля, методи, властивості, індексатори, оператори, події, делегати, класи, інтерфейси, структури.

Кожен клас може складатися з різних членів класу, які містять властивості, що описують дані класу, методи, що задають поведінку класу, і події, що забезпечують зв'язок між різними класами і об'єктами. Поля і властивості представляють відомості, що містяться в об'єкті. Поля подібні змінним, так як вони можуть бути прочитані або змінені безпосередньо.

Кожен об'єкт містить свій екземпляр полів класу.

class post

public string box;

Методи знаходяться в пам'яті в одному екземплярі і використовуються всіма об'єктами спільно, тому необхідно забезпечити роботу методів нестатичних екземплярів з полями саме того об'єкту, для якого вони були викликані. Для цього в будь-який нестатичний метод автоматично передається прихований параметр this, в якому зберігається посилання на поточний екземпляр об'єкта, що викликав функцію.

Це посилання є прихованим покажчиком на кожний нестатичний метод класу. Будь-який метод може використовувати ключове слово this для доступу до інших нестатичних методів і змінних цього об'єкта.

У мові C# дозволяється оголосити клас, який не розглядається як тип даних, і в якого зберігається єдина роль - роль модуля. Такий клас оголошується з модифікатором static. В цьому класі можуть бути задані константи, лише статичні поля і лише статичні методи. У нього немає конструкторів в звичайному сенсі цього слова, що дозволяють створювати об'єкти - екземпляри класу.

Статичним є клас, всі методи якого є статичними. Статичні класи не потребують створення об'єкту оператором new.

Статичний клас не може розглядатися як тип даних.

Композиція (агрегування за значенням) це більш суворий варіант агрегування, коли включається об'єкт може існувати тільки як частина контейнера. Якщо контейнер буде знищений, то і включений об'єкт теж буде знищений.

Під дружніми функціями розуміють член класу з модифікатором доступу internal доступний для всіх класів всередині однієї збірки.

Перевантаження - це створення більш ніж однієї процедури, конструктора примірника чи властивості в класі з однаковими іменами, але з різними типами аргументів. В своїй курсовій роботі я застосував перевантажений метод ToString

public override string ToString()

{

return Name + "|" + Adresa + "|" + Employees + "|" + Turnover + "|" + Profit + "|" + Box;

}

Оператор інкремента збільшує свій операнд на 1, а оператор декременту зменшує свій операнд на 1.

Тобто, оператор : x++; Збільшує на одиницю змінну x.

А оператор : х--; зменшує на одиницю змінну х.

В мові C# існує дві форми розглянутих операцій: префіксна і постфіксна. Якщо оператори ++ або -- записані після змінної (так, як написано вище) - це постфіксна форма. При цьому послідовно відбуваються наступні дії: старе значення змінної зберігається для використання в подальшому вираженні, в якому зустрілася ця змінна; І тільки після цього її значення ВІДРАЗУ Ж змінюється на 1.Якщо ці оператори записані перед змінної, ось так : ++х або --х, то це префиксна форма. При цьому послідовність дій така : СПОЧАТКУ змінна змінюється на 1; і тільки після цього використовується у виразі. Але якщо інкремент або декремент виконуються як абсолютно окремий від інших виразів оператор, то префиксна і Постфіксна форма призводять до однакового результату, тобто, при такому використанні немає ніякої різниці, де ми пишемо оператор.

Перевантаження операцій інкременту та декременту.

Для перевантаження оператора на користувальницький клас потрібне створення методу на класі з правильним підписом. Метод повинен бути названий "оператор Х", де Х є назва або символ оператора перевантаження. Унарні оператори мають один параметр, і бінарні оператори мають два параметри. У кожному випадку один параметр повинен бути того ж типу, класу або структури, яка оголошує оператор.

Спадкоємство є основною концепцією об'єктна-орієнтовного програмування (ООП). З його допомогою створюється ієрархія класів. Спадкоємство використовується для розширення функціональних можливостей класу. При цьому похідний клас успадковує усі методи і властивості базового класу. На відміну від С++, у С# заборонено множинне спадкоємство, тобто клас може успадкувати властивості і методи тільки від одного базового класу (предка). Множинне спадкоємство можна реалізувати за допомогою інтерфейсів. Таким чином, с С# є два типи спадкоємства : спадкоємство реалізації і спадкоємство інтерфейсів.

Механізм спадкоємства класів надає великі можливості організації коду і його багатократного використання. Вибір найбільш відповідних засобів для цілей конкретного проекту ґрунтується на знанні механізму їх роботи і взаємодії. Спадкоємство - важлива риса об'єктна-орієнтованого програмування. Воно призначене для відображення такої риси програмних систем як ієрархічність. Створення ієрархії класів дозволяє розширювати функціональні можливості класів в похідних класах, а також повторно використовувати код методів базових класів.

Спадкування буває відкритим (Public), закритим (Private) та захищеним (Protected). У всіх випадках клас D отримує доступ до відкритих і захищених членів B. Відмінності:

1. Відкрите - Відкриті члени B стають відкритими в D. Захищені B - захищеними D. Кажуть, що клас успадковує як інтерфейс, так і реалізацію предка.

2. Закрите - Відкриті і захищені члени B стають закритими в D. Застосовують коли клас повинен наслідувати тільки реалізацію.

3. Захищене - відкриті і захищені члени B стають захищеними в D.

Множинне спадкування в C# реалізується через інтерфейси.

Абстрактні класи і методи - при створенні ієрархії об'єктів для виключення коду, що повторюється, часто буває логічно виділити їх загальні властивості в один базовий клас. При цьому може виявитися, що створювати екземпляри такого класу не має сенсу, тому що жлдні реальні об'єкти їм не відповідають. - Такі класи називають абстрактними.

В абстрактному класі визначаються лише загальні призначення методів, які повинні бути реалізовані в похідних класах, але сам по собі цей клас не містить реалізації методів, а тільки їх сигнатуру ( тип значення, що повертається, ім'я методу і список параметрів).

При оголошенні абстрактного методу використовується модифікатор abstract, Абстрактний метод автоматично стає віртуальним, так що модифікатор virtual при оголошенні методу не використовується.

Абстрактний клас призначений тільки для створення ієрархії класів, не можна створити об'єкт абстрактного класу.

Якщо в класі є хоч би один абстрактний метод, весь клас також має бути описаний як абстрактний.

Поліморфізм - одна з базових концепцій об'єктна-орієнтованого програмування, що дозволяє мати різні реалізації для одного і того ж методу, які будуть вибиратися залежно від типу об'єкту, переданого до методу при його виклику. Ця концепція с реалізується як перевантаження (методів, операцій).

При визначенні віртуального методу у складі базового класу перед типом значення, що повертається, указується ключове слово virtual а при перевизначенні віртуального методу в похідному класі використовується модифікатор override.Віртуальний метод не може бути визначений з модифікатором static або abstract. Перевизначений віртуальний метод повинен мати такий саме набір параметрів, як і однойменний метод базового класу. За допомогою віртуальних методів реалізується один з основних принципів об'єктна - орієнтованого програмування - поліморфізм. Це слово в перекладі з грецького означає "багато форм", що в даному випадку означає "один виклик - багато методів".

Динамічні структури даних - це структури даних, пам'ять під які виділяється і звільняється в міру необхідності. Динамічні структури даних в процесі існування в пам'яті можуть змінювати не тільки число складових їх елементів, а й характер зв'язків між елементами. При цьому не враховується зміна вмісту самих елементів даних. Така особливість динамічних структур, як мінливість їх розміру та характеру відносин між елементами, призводить до того, що на етапі створення машинного коду програма-компілятор не може виділити для всієї структури в цілому ділянку пам'яті фіксованого розміру, а також не може зіставити з окремими компонентами структури конкретні адреси. Для вирішення проблеми адресації динамічних структур даних використовується метод, званий динамічним розподілом пам'яті, тобто пам'ять під окремі елементи виділяється в момент, коли вони "починають існувати" в процесі виконання програми, а не під час компіляції. Компілятор в цьому випадку виділяє фіксований обсяг пам'яті для зберігання адреси динамічно розміщується елемента, а не самого елемента.

Динамічна структура даних характеризується тим що:

· Вона не має імені;

· Їй виділяється пам'ять в процесі виконання програми;

· Кількість елементів структури може не фіксуватися;

· Розмірність структури може змінюватися в процесі виконання програми;

· В процесі виконання програми може змінюватися характер взаємозв'язку між елементами структури.

Необхідність в динамічних структурах даних зазвичай виникає в наступних випадках.

· Використовуються змінні, що мають досить великий розмір (наприклад, масиви великої розмірності), необхідні в одних частинах програми і абсолютно не потрібні в інших.

· У процесі роботи програми потрібен масив, список чи інша структура, розмір якої змінюється в широких межах і важко передбачуваний.

· Коли розмір даних, що обробляються в програмі, перевищує обсяг сегмента даних.

Разом з тим, зв'язне уявлення не позбавлено і недоліків, основними з яких є наступні:

· На поля, що містять покажчики для зв'язування елементів один з одним, витрачається додаткова пам'ять;

· Доступ до елементів зв'язної структури може бути менш ефективним за часом. Порядок роботи з динамічними структурами даних наступний:

· Створити (відвести місце в динамічній пам'яті);

· Працювати за допомогою покажчика;

· Видалити (звільнити зайняте структурою місце).

У багатьох задачах потрібно використовувати дані, в яких конфігурація, розміри і склад можуть змінюватися в процесі виконання програми. Для їх подання використовують динамічні інформаційні структури. До таких структур відносять:

· Односпрямовані (однозв'язні) списки;

· Двонаправлені (двузв'язні) списки;

· Циклічні списки;

· Стек;

· Черга;

· Бінарні дерева.

Препроцессори

У С # визначено ряд директив препроцесора, що впливають на інтерпретацію вихідного коду програми компілятором. Ці директиви визначають порядок інтерпретації тексту програми перед її трансляцією в об'єктний код в тому вихідному файлі, де вони з'являються. Термін директива препроцесора з'явився у зв'язку з тим що подібні інструкції за традицією оброблялися на окремій стадії компіляції, званої препроцесором. Обробляти директиви на окремій стадії препроцесора в сучасних компіляторах вже не потрібно, але сама її назва закріпилася. Нижче наведені директиви препроцесора, визначені в С #

#define #elif #else #endif #endregion #error

#if #line #pragma #region #undef #warning

Шаблони класів.

Шаблони класів визначають сімейство пов'язаних класів, заснованих на типі аргументів, переданих класу при створенні його примірника.

Шаблони функцій.

Шаблони функцій схожі на шаблони класів, але визначають сімейство функцій. За допомогою шаблонів функцій можна задавати набори функцій, заснованих на одному коді, але діють в різних типах або класах.

Обробка виняткових ситуацій.

Блок try використовується програмістами C # для розбиття на розділи коду, який може порушуватися винятком. Пов'язані з ним блоки catch використовуються для обробки можливих винятків. Блок finally, що містить код, що виконується незалежно від того, чи викликано виняток у блоці try, наприклад звільнення ресурсів, виділених блоку try. Блоку try потрібно один або кілька пов'язаних блоків catch або блок finally (або і те, і інше).

Стандартні виключення С++. Альтернативні методи обробки

Фундаментальна ідея обробки помилок полягає в тому, що функція, яка виявила проблему, але не знає як її вирішити, генерує виняток у надії, що викликала її (безпосередньо чи опосередковано) функція зможе вирішити виниклу проблему. Функція, яка хоче вирішувати проблеми даного типу, може вказати, що вона перехоплює такі винятки. Механізм обробки виключень надає альтернативу традиційним методам в тих випадках, коли вони не достатні, чи не елегантні і схильні помилками. Він надає спосіб явного відділення коду обробки помилок від "звичайного" коду, роблячи таким чином програму більш читабельною і краще підходить для різних інструментальних засобів. Механізм обробки виключень надає більш регулярний спосіб обробки помилок, спрощуючи в результаті взаємодія між окремо написаними фрагментами коду.

Огляд стандартної бібліотеки С++

Стандартна бібліотека С++ включає стандартну бібліотеку Сі з невеликими змінами, які роблять її відповіднішою для мови С++. Інша велика частина бібліотеки С++ заснована на Стандартній Бібліотеці Шаблонів (STL). Вона надає такі важливі інструменти, як контейнери (наприклад, вектори і списки) і ітератори (узагальнені вказівники), що надають доступ до цих контейнерів як до масивів. Крім того, STL дозволяє схожим чином працювати і з іншими типами контейнерів, наприклад, асоціативними списками, стеками, чергами.

Використовуючи шаблони, можна писати узагальнені алгоритми, здатні працювати з будь-якими контейнерами або послідовностями, доступ до членів яких забезпечують ітератори.

Так само, як і в С, можливості бібліотек активізуються використанням директиви #include для включення стандартних файлів. Всього в стандарті Сі++ визначено 50 таких файлів.

Загальна характеристика контейнерних класів

Контейнерами називаються об'єкти, що містять інші об'єкти. Контейнери управляють розміщенням об'єктів в оперативній пам'яті, використовуючи конструктори, видаляють об'єкти з памяті за допомогою деструкторів, а також додають і видаляють об'єкти за допомогою операцій вставки й видалення. У стандартній бібліотеці описано 10 шаблонних класів контейнерів.

1) Vector Вектор.

2) List Двозв'язний список.

3) Deque Двостороння черга.

4) Set Множина.

5) Multiset Мультмножина.

6) Map Асоціативний масив, що містить унікальні ключі й значення.

7) Multimap Асоціативний масив, що допускає дублювання ключів і значень.

8) Stack Стек.

9) Queue Черга.

10) Priority_queue Черга із пріоритетом.

11) Bitset Бітовий набір.

Послідовні контейнери

Послідовність - це різновид контейнерів, що містять скінчену множину однотипних об'єктів, упорядкованих у лінійному порядку. У бібліотеці STL передбачено три види послідовних контейнерів : вектор (клас vector), список (клас list) і двостороння черга (клас deque). Крім того, вони є базовими класами для створення більше складних контейнерів - стека (клас stack). Черги (клас queue) і черги із пріоритетом (клас priority_queue), Для кожної з послідовностей передбачений свій набір операцій, але існують операції, загальні для всіх послідовностей.

Асоціативні контейнери

Асоціативні контейнери - це структури даних, що забезпечують швидкий пошук даних по ключі. У стандартній бібліотеці шаблонів передбачено чотири різновиди асоціативних контейнерів : set (множина), multiset (мультимножина), map (асоціативний масив) і multimap (асоціативний мультимасив). Терміни "мультимножина" і "мультимассив" означають, що ці контейнери допускають дублікати елементів, на відміну від множини й масиву, у яких елементи повинні бути унікальними.

Асоціативні контейнери залежать від двох параметрів - Key (ключ) і Compare (відношення повного впорядкування по ключі Key). Класи set і multiset являють собою "вырожденные" асоціативні контейнери, у яких значення не важливі - всі операції здійснюються через ключі. Контейнер класу set повинен складатися з унікальних ключів, а об'єкт класу multiset допускає дублікати. У класах map й multimap зберігаються пари, що складаються з об'єктів довільного типу Т, пов'язаних з об'єктами класу Key.

Ітератор асоціативного контейнера є двунаправленим. Операція вставки не впливає на коректність ітераторів і посилань на елементи контейнера, операція видалення анулює лише літератори й посилання, установлені на вилучені елементи. Крім того, ітератори асоціативних контейнерів переміщаються по контейнері в порядку зростання ключів.

Адаптери стандартних контейнерів

Шаблонові класи vector, list й deque описують всі основні операції над послідовностями. Хоча вони містять досить велику кількість однакових операцій, по своїй структурі й принципам функціонування жоден із цих класів не можна замінити іншим. Завдяки тому, що в класах vector, list й deque реалізовані базові операції, їх можна використати як основу для створення більше складних структур - стеків і черг. Отже, для правильного визначення об'єктів адаптерів послідовностей у програму необхідно включати два заголовки : один повинен містити визначення шаблонового класу адаптера, а іншої - визначення базисного класу.

Алгоритми і функції стандартної бібліотеки

Алгоритм (algorithm) - це визначення обчислювальної процедури. У бібліотеці STL є група функцій, які виконують деякі стандартні дії, наприклад пошук, перетворення, сортування, копіювання тощо. Вони називаються алгоритмами. Параметрами для алгоритмів, зазвичай, служать ітератори. Алгоритму не цікавлять до типу переданого йому ітератора. Головне, щоб останній підпадав під певну категорію. Приміром, якщо параметром алгоритму може бути односпрямованийитератор, то підставляємий ітератор має бути однонаправленим, або двунаправленним, або житератором довільного доступу

Функціональний об'єкт (functor) - це заховання функції в об'єкті для використання іншими компонентами.

Достоїнства і недоліки об'єктно - орієнтованого стилю програмування.

Об'єктно-орієнтований підхід має такі переваги, як:

· Зменшення складності програмного забезпечення;

· Підвищення надійності програмного забезпечення;

· Забезпечення можливості модифікації окремих компонентів програмного забезпечення без зміни інших його компонентів;

· Забезпечення можливості повторного використання окремих компонентів програмного забезпечення.

· Скорочується час на розробку, який може бути віддано іншим завданням.

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

· Коли якийсь компонент використовується відразу декількома клієнтами, поліпшення, що вносяться до його код, одночасно надають позитивний вплив і на безліч працюючих з ним програм.

· Якщо програма спирається на стандартні компоненти, її структура і призначений для користувача інтерфейс стають більш уніфікованими, що полегшує її розуміння і спрощує використання.

До недоліків об'єктно-орієнтованого програмування відносяться :

Документування класів - завдання більш важке, ніж це було у випадку процедур та модулів. Оскільки будь-який метод може бути перевизначений, в документації має говоритися не тільки про те, що робить даний метод, але і про те, в якому контексті він викликається. Адже перевизначені методи звичайно викликаються не клієнтом, а самим каркасом. Таким чином, програміст повинен знати, які умови виконуються, коли викликається даний метод. Для абстрактних методів, які порожні, в документації має говоритися про те, для яких цілей передбачається використовувати переобумовлений метод.

Систематичне застосування об'єктно-орієнтованого підходу дозволяє розробляти добре структуровані, надійні в експлуатації, досить просто модифікуються програмні системи. Цим пояснюється інтерес програмістів до об'єктно-орієнтованого підходу й об'єктно-орієнтованим мовам програмування. ООП є одним з напрямків теоретичного і прикладного програмування, що найбільш інтенсивно розвивається.

  • 2. Постановка задачі
  • 1. Розробити програму, що використовуючи стек виконує такі процедури:
  • 1.1 Додає в створену структуру нові елементи.
  • 1.2 Видаляє непотрібні елементи.
  • 1.3 Виконує пошук серед елементів.
  • 1.3.1 Точний пошук за назвою.
  • 1.3.2 Пошук за яким оборот перевищує задане число.
  • 1.3.3 Пошук за яким виручка перевищує задане число.
  • 1.4 Дозволяє коректування (редагування) заданого елемента.
  • 1.5 Дозволяє передивитись усі елементи які були створені.
  • 1.6 Виконує сортування полів за зростанням та алфавітом за допомогою списків.
  • 1.6.1 Сортування за назвою.
  • 1.6.2 Сортування за адресою.
  • 1.6.3 Сортування за кількістю співробітників.
  • 1.6.4 Сортування за оборотом.
  • 1.6.5 Сортування за виручкою.
  • 1.7 Переміщення елемента між структурами.
  • 1.8 Записує елемент у файл.
  • 1.9 Видаляє елемент з файлу.
  • 1.10 Переміщує елемент з файлу видаляючи при цьому його дублікат з інших файлів.
  • 1.11 Виконує сортування окремо для кожного з файлів за алфавітом та за зростанням за допомогою списків.
  • 2. Створення форми на якій зручно розміщенні елементи управління програмою (кнопки, текстові поля, події та обробка подій тощо).
  • 3. Контроль за заповненням всіх полів при зберіганні елемента.
  • 4. Створюємо абстрактний клас Офіс.
  • 4.1 Створюємо поля до абстрактного класу Офіс.
  • 4.1.1 Створюємо поле "Назва".
  • 4.1.2 Створюємо поле "Адреса".
  • 4.1.3 Створюємо поле "Кількість співробітників".
  • 4.1.4 Створюємо поле "Оборот".
  • 4.1.5 Створюємо поле "Виручка".
  • 4.1.6 Створюємо масив записів торговельний, почтовий та банковський офіси.
  • 4.1.7 Створюємо масив записів до кожної із записів офісу свій масив зі списками.
  • 4.1.7.1 Торговельному офісу створюєм масив записів : Палатка, магазин, супермаркет, гіпермаркет.
  • 4.1.7.2 Почтовому офісу створюєм масив записів : Письмо, Бандероль, посилка.
  • 4.1.7.3 Банківському офісу створюєм масив записів : Державний та приватний.
  • 4.2 Створюємо властивості до абстрактного класу Офіс.
  • 4.3 Створюємо базовий конструктор до абстрактного класу Офіс.
  • 4.4 Створюємо 3 похідні класи на базі абстрактного класу Офіс.
  • 4.5 Створюємо в кожному похідному класу конструктор.
  • 4.6 Перевизначаємо метод ToString() для кожного класу.
  • 4.7 Додаємо у програму процедури та функції для скорочення кількості рядків коду і багатократного використання у програмі однакових дій.
  • 3. Розробка ієрархії класів
    • 3.1 Створення абстрактного класу Офіс
    • abstract class Office
    • Створюємо поля до абстрактного класу Офіс : Назва, адреса, кількість співробітників, оборот, виручка.
    • public string Name; // Назва офіса
    • public string Adresa; // Адреса офісу
    • public int Employees; // Кількість співробітників
    • public int Turnover; // Оборот офіса
    • public int Profit; // Выручка офіса
    • Властивості для організації доступу до полів класу.
    • Властивість для поля Назва
    • public string name
    • {
    • get { return Name; }
    • set { Name = value; }
    • }
    • Властивість для поля Адреса
    • public string adresa
    • {
    • get { return Adresa; }
    • set { Adresa = value; }
    • }
    • Властивість для поля кількість співробітників
    • public int employees
    • {
    • get { return Employees; }
    • set { Employees = value; }
    • }
    • Властивість для поля оборот
    • public int turnover
    • {
    • get { return Turnover; }
    • set { Turnover = value; }
    • }
    • Властивість для поля Виручка
    • public int profit
    • {
    • get { return Profit; }
    • set { Profit = value; }
    • }
    • Створюємо базовий конструктор Офіс
    • public Office(string N, string A, int E, int T, int P)
    • {
    • Name = N; // Название
    • Adresa = A; // Адрес
    • Employees = E; // Кол-во сотрудников
    • Turnover = T; // Оборот
    • Profit = P; // Выручка
    • }
    • 3.2 Створюємо клас Торговий який є спадкоємцем батьківського класу Офіс
    • class Business : Office
    • Створюємо у класі Business поле місце продажу.
    • public string Workplace; // місце продажу
    • Створюємо конструктор класу Торговий на базі абстрактного класу Офіс
    • public Business(string N, string A, int E, int T, int P, string W) :
    • base(N, A, E, T, P)
    • {
    • Workplace = W;
    • }
    • Перевизначаємо метод ToString() та пристосовуємо до нашого класу Торговий.
    • public override string ToString()
    • {
    • return Name + "|" + Adresa + "|" + Employees + "|" + Turnover + "|" + Profit + "|" + Workplace;
    • }
    • 3.3 Створюємо клас Почтовий який є спадкоємцем батьківського класу Офіс
    • class Post : Office
    • Створюємо у класі Post поле багаж.
    • public string Box;
    • Створюємо конструктор класу Почтовий на базі абстрактного класу Офіс
    • public Post(string N, string A, int E, int T, int P, string B) :
    • base(N, A, E, T, P)
    • {
    • Box = B; // Багаж
    • }
    • Перевизначаємо метод ToString() та пристосовуємо до нашого класу Почтовий.
    • public override string ToString()
    • {
    • return Name + "|" + Adresa + "|" + Employees + "|" + Turnover + "|" + Profit + "|" + Box;
    • }
    • 3.4 Створюємо клас Банк який є спадкоємцем батьківського класу Офіс
    • class Bank : Office
    • Створюємо у класі Bank поле тип.
    • public string Mode;
    • Створюємо конструктор класу Банк на базі абстрактного класу Офіс
    • public Bank(string N, string A, int E, int T, int P, string M) :
    • base(N, A, E, T, P)
    • {
    • Mode = M;
    • }
    • Перевизначаємо метод ToString() та пристосовуємо до нашого класу Банк.
    • public override string ToString()
    • {
    • return Name + "|" + Adresa + "|" + Employees + "|" + Turnover + "|" + Profit + "|" + Mode;
    • }
  • 4. Розробка алгоритму рішення задач
    • 4.1 Алгоритм додавання елементу у стек і зберігання його у файлі
    • Загальний опис алгоритму додавання нового об'єкту в стек та зберігання об'єкту у файлі обраного офісу.
    • · Спочатку перевіряємо заповнення усіх полів (Назву, адресу, кількість працівників, обороту, виручки, вибору офісу і його типу), якщо хоч одне поле не заповнене, то видаємо на екран повідомлення з назвою поля яке виявилось пустим, при цьому заповнені поля не зникають.
    • · Потім створюємо об'єкт з нашими даними в конструкторі в залежності від обраного офісу.
    • · Далі додаємо об'єкт на вершину стека.
    • · Зберігаємо об'єкт у вигляді строки у файлі офісу якого ми обрали.
    • · Кінець виконування алгоритму.
    • 4.2 Алгоритм для перегляду вмісту стека
    • · Створюємо копію стека під іншим ім'ям .
    • · Перевіряємо чи є у стеку елементи, якщо ні то виводимо повідомлення у листбокс і завершуємо алгоритм, якщо є тоді продовжуємо виконувати програму,
    • · Поки кількість елементів у стеку не дорівнює нулю виводимо на форму у листбоксі елементи по одному на рядок, замінюючи символ "|" на символ "\t"
    • · Кінець алгоритму.
    • 4.3 Алгоритм для редагування елемента у стеку
    • · Спочатку перевіряємо заповнення усіх полів (Назву, адресу, кількість працівників, обороту, виручки, вибору офісу і його типу), якщо хоч одне поле не заповнене, то викликаємо на екран повідомлення з назвою поля яке виявилося пустим, при цьому заповнені поля не зникають.
    • · Робимо копію стека під іншим ім'ям .
    • · Заводимо додатково 3 рядкові змінні типу string : str, str2. s1.
    • · Присвоюємо строковій змінній str обраний нами рядок з листбоксу замінюючи символ "\t" на символ "|"
    • · Потім створюємо об'єкт з нашими даними в конструкторі в залежності від обраного офісу.
    • · Очищаємо стек від усіх елементів.
    • · Поки копія стеку більше 0 присвоюємо змінній s1 наведений у рядок елемент зі стеку. Виконуємо : якщо змінна s1 містить рядок змінній str додаємо до стеку об'єкт з нашими даними у конструкторі, якщо ні - додаємо до стеку змінну s1.
    • · Чистимо вміст змінної str2.
    • · Оголошуємо файлову змінну read і зв'язуємо її з файлом.
    • · Введемо у змінну str2 вміст файла за допомогою файлової змінної read.
    • · Зачинемо файл, який зв'язали файловою змінною read.
    • · Якщо у файлі знаходиться розшукуваний рядок тоді замінюємо цей рядок на виправлений рядок, тобто, якщо змінна str2 містить змінну str тоді виконуємо блок команд, а саме :
    • · В змінній str2 знаходимо старий рядок який зберігається в змінній str і замінюємо його новим об'єктом.
    • · Оголошуємо об'єкт write і зв'язуємо її з файлом одного з офісів. Записуємо у об'єкт write змінну str2.
    • · Зачиняємо файл.
    • · Якщо цього рядка не знайдено то виконуємо наступні дії :
    • · Дописуємо у файл новий об'єкт.
    • · Передивляємось усі файли один за одним і якщо знаходимо у файлі дублікат то замінюємо цей рядок новим рядком.
    • · Створюємо копію стеку.
    • · Чистимо Листбокс.
    • · Поки залишаються елементи у стеку виводимо їх по одному рядку у Листбокс.
    • · Видаляємо усі записи з полів.
    • · Чистимо всі дані в глобальній змінній stroka.
    • 4.4 Алгоритм для знищення елемента у стеку
    • · Створюємо копію стеку.
    • · Заводимо додатково 2 рядкові змінні типу string : str, s1.
    • · Вводимо додаткову цілу змінну типа integer : nomer.
    • · Присвоюємо строковій змінній str обраний нами рядок з листбоксу замінюючи символ "\t" на символ "|"
    • · Визначаємо за назвою офіса в якому файлі треба видалити обраний нами рядок .
    • · Створюємо новий об'єкт з нашими даними в конструкторі в залежності від обраного офісу завдяки тому, що всі наші дані знаходяться у полях форми.
    • · Заводимо нову рядкову змінну str2
    • · Присвоюємо змінній str2 новий об'єкт приведений до рядкового типу.
    • · Методом Clear() видаляємо усі елементи зі старого стеку.
    • · Виконуємо цикл Пока в новому стеку кількість елементів більше нуля виконуємо : беремо елемент з верху стеку і приводимо його до рядкового типу для присвоєння змінній s1
    • · Якщо змінна s1 тримає у собі змінну str тоді продовжуємо цикл Поки далі та й повертаємось до його початку.
    • · Якщо змінна s1 не тримає у собі змінну str тоді додаємо у старий стек змінну s1
    • · Створюємо рядкову змінну str1.
    • · Оголошуємо файлову змінну read і зв'язуємо її з файлом.
    • · Введемо у змінну str1 вміст файла за допомогою файлової змінної read.
    • · Зачинемо файл, який зв'язали файловою змінною read.
    • · Оголошуємо об'єкт file1 і зв'язуємо її з файлом одного з офісів.
    • · Якщо у змінній str1 розшукуваний індекс у змінній str не дорівнює -1 тоді замінюємо цей рядок на виправлений рядок, тоді можна видалити зі змінної str1 змінну str2 тобто, якщо змінна str1 містить змінну str тоді виконуємо блок команд, а саме :
    • · В змінній str1 знаходимо початковий індекс рядка і знаходимо кількість символів завдяки рядковій змінній str2, яку потрібно видалити враховуючи 2 символи які позначають кінець рядка зі змінної str1.
    • · Записуємо у файлову змінну file1 рядкову змінну str1 і зачиняємо файл, який зв'язали файловою змінною file1.
    • · Кінець алгоритму.
    • 4.5 Алгоритм пошуку у стеку по точному збігу під рядка в рядку
    • · Чистимо Листбокс.
    • · Створюємо копію стеку.
    • · Заводимо змінну булевого типу b.
    • · Заводимо числову змінну a1 і присвоюємо їй початкове значення 0.
    • · Перевіряємо якщо кількість елементів у стеку дорівнює 0 тоді виводимо у листбокс текст Стек порожній, якщо ні виконуємо алгоритм далі.
    • · Якщо поле пошуку дорівнює 0 тоді виводимо повідомлення "Заповните поле пошуку" інакше починаємо цикл Поки.
    • · Поки в новому стеку кількість елементів більше 0 виконуємо :
    • · Беремо з вершини стеку елемент і замінюємо в ньому символ "|" на символ "\t" та присвоюємо змінний s1.
    • · З поля пошуку присвоюємо змінній s2 значення яке ми хочимо знайти у стеку.
    • · Присвоюємо змінній b значення true, якщо змінна s1 містить змінну s2 і значення false, якщо змінна s1 не містить змінну s2.
    • · Якщо змінна b має значення true вивести елемент зі стеку у листбокс в рядок та підвищіти змінну a1 на одиницю.
    • · Якщо a1 більше за 0 вивести у форму текст Знайшли і значення змінної a1.
    • · Якщо a1 дорівнює 0 вивести у форму текст Знайшли 0.
    • · Кінець алгоритму.
    • 4.6 Алгоритм пошуку у стеку за яким оборот перевищує задане число
    • · Створюємо копію стеку.
    • · Чистимо Листбокс.
    • · Заводимо рядкову змінну words.
    • · Заводимо числову змінну kol і присвоюємо їй початкове значення 0.
    • · Якщо поле за яким оборот перевищує задане число виявилося не заповненим, тоді звертаємо увагу користувача на незаповнене поле з числом за яким треба проводити пошук.
    • · Якщо в полі число є то виконуємо пошук у циклі Поки :
    • · Беремо з вершини стеку елемент та присвоюємо змінний words.
    • · Використовуючи метод Спліт з роздільником "|" одержуємо рядковий масив words1.
    • · Якщо третій елемент масиву words1 більший за число вказане в полі тоді виводимо елемент у листбокс та збільшуємо змінну kol на одиницю.
    • · Кінець алгоритму.
    • 4.7 Алгоритм пошуку у стеку за яким виручка перевищує задане число
    • · Створюємо копію стеку.
    • · Чистимо Листбокс.
    • · Заводимо рядкову змінну words.
    • · Заводимо числову змінну kol і присвоюємо їй початкове значення 0.
    • · Якщо поле за яким виручка перевищує задане число виявилося не заповненим, тоді звертаємо увагу користувача на незаповнене поле з числом за яким треба проводити пошук.
    • · Якщо в полі число є то виконуємо пошук у циклі Поки :
    • · Беремо з вершини стеку елемент та присвоюємо змінний words.
    • · Використовуючи метод Спліт з роздільником "|" одержуємо рядковий масив words1.
    • · Якщо четвертий елемент масиву words1 більший за число вказане в полі тоді виводимо елемент у листбокс та збільшуємо змінну kol на одиницю.
    • · Кінець алгоритму.
    • 4.8 Алгоритм сортування у стеку за алфавітом за назвою
    • · Заводимо нову рядкову змінну read і ініціалізуємо її.
    • · Використовуючи списки створюємо список Ot на базі абстрактного класу Office.
    • · Починаємо цикл Поки стек більше 0 виконуємо :
    • · Беремо з вершини стеку елемент перетворюємо його на рядок та присвоюємо змінний read.
    • · Використовуючи метод Спліт з роздільником "|" одержуємо рядковий масив words.
    • · Додаємо у список Ot рядок з 6 елементів рядкового масиву words.
    • · Сортуємо за алфавітом за допомогою делегатів список за назвою.
    • · Збираємо у стек всі елементи зі списку Ot.
    • · Чистимо Листбокс.
    • · Створюємо копію стеку та у циклі поки стек більше 0 виводимо кожен елемент у листбокс розташований за алфавітом.
    • · Кінець алгоритму.
    • 4.9 Алгоритм сортування у стеку по зростанню за виручкою
    • · Заводимо нову рядкову змінну read і ініціалізуємо її.
    • · Використовуючи списки створюємо список Ot на базі абстрактного класу Office.
    • · Починаємо цикл Поки стек більше 0 виконуємо :
    • · Беремо з вершини стеку елемент перетворюємо його на рядок та присвоюємо змінний read.
    • · Використовуючи метод Спліт з роздільником "|" одержуємо рядковий масив words.
    • · Додаємо у список Ot рядок з 6 елементів рядкового масиву words.
    • · Сортуємо список по зростанню за допомогою делегатів за виручкою.
    • · Збираємо у стек всі елементи зі списку Ot.
    • · Чистимо Листбокс.
    • · Створюємо копію стеку та у циклі поки виводимо кожен елемент у листбокс розташований за алфавітом.
    • · Кінець алгоритму.
    • 4.10 Алгоритм сортування у файлі за алфавітом
    • · Створюємо Список з назвою класа який ми обрали для сортування.
    • · Оголошуємо файлову змінну file1 і зв'язуємо її з нашим файлом.
    • · Починаємо цикл Поки у файлі не закінчились рядки виконуємо:
    • · Читаємо один рядок з файлу у змінну read.
    • · Використовуючи метод Спліт з роздільником "|" одержуємо рядковий масив words.
    • · Додаємо у список 6 елементів рядкового масиву words.
    • · Зачинемо файл, який зв'язали файловою змінною file1.
    • · Сортуємо за алфавітом за допомогою делегатів список за назвою.
    • · Оголошуємо об'єкт write і зв'язуємо її з нашим файлом.
    • · За допомогою циклу Foreach записуємо по одному елементи зі списку до нашого файлу.
    • · Зачинемо файл, який зв'язали файловою змінною write.
    • · Кінець алгоритму.
  • 5. Розробка програми рішення задачі
  • Після отримання завдання на написання курсового проекту було прийнято рішення розподілити роботу над курсовим проектом на декілька етапів які б дали змогу краще виконати поставлену задачу і розподілити зусилля на її виконання.
  • 1) Збір інформації про завдання.
  • 2) Розкриття сенсу задачі.
  • 3) Визначення кінцевих цілей рішення задачі.
  • 4) Визначення форми видачі результатів.
  • 5) Опис даних (їх типів, діапазонів величин, структури, назв і т. п.).
  • 6) Аналіз існуючих аналогів.
  • 7) Розробка структур даних.
  • 8) Уточнення способів організації даних.
  • 9) Написання програми і її налагодження.
  • 10) Виявлення помилок та їх усунення.
  • 11) Вдосконалення програми.
  • 12) Складання документації до вирішеної задачі,
  • В першу чергу необхідно було з'ясувати які дані буде обробляти програма. Як програма буде взаємодіяти з користувачем. Яким чином зберігати введені користувачем дані у програму. Яким чином відобразити ці дані у програмі. Які наступні дії можна проводити з цим набором даних. Після отримання відповіді на ці питання стало можливим переходити до наступного етапу виконання курсової роботи.
  • В процесі підготовки до написання програми створювалася ієрархія трьох класів торговий, поштовий та банковий на чолі з абстрактним класом Office.
  • Доповнювалися поля притаманні кожному з класів та будувався окремий конструктор для кожного класу на базі конструктора абстрактного класу.
  • Поступово ставало зрозумілим якою буде програми у процесі написання коду. Для зменшення рядків у коді використовувалися процедури і функції.
  • 6. Розробка керівництва користувача
  • Для зручності роботи користувача була створена форма на якій знаходяться :
  • 1) Тексти для усвідомлення користувачем призначення полів, об'єктів для вибору та кнопок.
  • 2) Поля для заповнення користувачем.
  • 3) Об'єкти для вибору зі списку.
  • 4) Вікно для перегляду створених елементів користувачем.
  • 5) Перегляд вмісту кожного файла створеного при запуску програми.
  • Форма для створення одного елемента стеку має наступний вигляд
  • Для завантаження в стек елементів з усіх файлів створена кнопка "Загрузка в стек со всех файлов"
  • Якщо потрібно передивитись вміст стеку то для цього на формі призначена кнопка
  • Вікно зі вмістом стеку виглядає наступним чином.
  • Для перегляду кількості елементів у стеку призначена кнопка "Размер стека"
  • Після її натиснення на формі з'явиться напис -
  • Для пошуку потрібного елемента у стеку призначена кнопка , а текст
  • за яким проводити пошук потрібно вписати у це поле
  • інакше програма буде видавати наступне повідомлення
  • Для сортування елементів у стеку за алфавітом та впорядкувати елементи за зростанням призначений об'єкт для вибору за списком
  • Якщо потрібно обрати елементи в яких оборот або виручка більше за вказану у полі то для цього призначені 2 кнопки
  • Ще в програмі передбачена можливість сортування у кожному файлі окремо, за алфавітом за їх назвою для цього призначений 2 об'єкта для вибору за списком 1)
  • та об'єкт 2)
  • Ще в програмі можливо переглянути вміст кожного файлу у окремому вікні,
  • для цього існує три кнопки
  • Для редагування елемента у стеку потрібно вибрати елемент зі списку як це написано над вікном перегляду стеку.
  • Тоді обраний користувачем елемент з'явиться у полі вводу на формі :
  • Після зміни елемента для збереження його у стеку та файлу, при цьому, якщо елемент буде переміщений у інший файл то його дублікат у файлі буде знищено. Для цього призначена кнопка .
  • Якщо потрібно видалити елемент зі стеку і файлу то для цього потрібно натиснути на кнопку
  • Якщо не потрібно редагувати або знищувати елемент у стек або файлу то для цього потрібно натиснути на кнопку
  • Також в програмі можна за допомогою 2 кнопок і переміщуватись по рядках у вікні перегляду стеку. При цьому кожен рядок буде розбиватись на окремі поля і відображатися у вікні редагування елемента. Якщо при переміщенні вперед по рядках буде досягнуто останнього рядка, то переглядання почнеться з самого початку і навпаки при переміщенні назад, якщо це виявиться перший рядок.
  • Висновок
  • Під час виконання цього курсового проекту в мене з'явилися навички й уміння самостійно розробляти програми з використанням деяких засобів ООП. Була досягнута мета курсового проекту розробити програму за допомогою якої стало можливим легко виконувати операції додавання, редагування та видалення елементів у стеку. Розташовувати елементи у стеку за алфавітом та за зростанням. Зберігати та завантажувати елементи стеку у файлах та виконувати сортування всередині файлів. Також в програмі реалізований механізм зручного керування програмою за допомогою розташування на формі : кнопок, вказівок у вигляді появи попереджуючих вікон, підказок біля поля для вводу тексту або чисел, вікон перегляду, об'єктів вибору за списком тощо.
  • За час написання курсового проекту закріпив теоретичні знання, отриманих з лекцій, літератури та інтернету, поглиблюючи й узагальнюючи них при розв'язуванні конкретних програмних задач.
  • На жаль в даному курсовому проекту не вдалося впровадити перегляд стеку у табличній формі в якій кожна частина рядка займала б свою комірку. Це б дозволило редагувати та зберігати дані безпосередньо в таблиці, а саме в стеку і файлі.
  • В подальшому в програмі можна добавити можливість зберігання усіх дій які виконував користувач. Можливість одночасної роботи декількох користувачів. Організувати систему допуску до даних різним користувачам. Розробити контроль за заповнюванням записів у стек та файл. Розробити систему підказок для зручності роботи користувача. Автоматично, в кінці робочого дня забезпечити зберігання введених даних в архів на інший носій, , що виключає втрату даних при будь-яких обставин.
  • Список використаної літератури
  • Основна література :
  • 1) C# 2005 и платформа .NET 3.0 для профессионалов. Кристиан Нейгел, Билл Ивьен, Джей Глинн, Морган Скиннер, Карли Уотсон. "ДИАЛЕКТИКА" Москва. Санкт-Петербург. Киев. 2008 р. - 1790 с.
  • 2) Полное руководство C# 4.0 Герберт Шилдт "Вильямс". Москва. Санкт-Петербург. Киев. 2007 р. - 776 с.
  • 3) Язык C#. Краткое описание и введение в технологии программирования. Котов О.М. Екатеринбург Издательство Уральского Университета. Учебное издание. 2014 г. 210 с.
  • Додаткова література :
  • 1) Мова C# Базовий курс. 2-видання. Подбельський В.В. - 408 с.
  • 2) Язык программирования С# 2005 и платформа .NET 2.0 Эндрю Троелсен, "Вильямс" Москва. Санкт-Петербург. Киев. 2011 р. - 1168 с.
  • 3) Сборник задач по программированию 2- видання. Златопольський Д.М. "БХВ- Петербург". Санкт-Петербург. 2007 р. - 122с.
  • Інтернет - ресурси
  • Бібліотека MSDN розділ - Довідник по C#
  • https://msdn.microsoft.com/ru-ru/library/618ayhy6.aspx
  • Размещено на Allbest.ru
...

Подобные документы

  • Поняття абстрактного класу в об’єктно-орієнтованому програмуванні. Описання класу pruzhyna, створення консольної програми для обчислення коефіцієнта передачі пружини стискання з циліндричної проволоки круглого перетину за заданою формулою і параметрами.

    курсовая работа [100,7 K], добавлен 25.11.2011

  • Об’єктно-орієнтоване програмування мовою С++. Основні принципи об’єктно-орієнтованого програмування. Розробка класів з використанням технології візуального програмування. Розробка класу classProgressBar. Базовий клас font. Методи тестування програми.

    курсовая работа [211,3 K], добавлен 19.08.2010

  • Особливості об'єктно-орієнтованого програмування. Розробка програми для елементарних математичних розрахунків, виведення результату на екран та запису у файлі. Сортування слів у рядку. Програма, яка реалізовує ходи шахових фігур. Програма-калькулятор.

    отчет по практике [2,0 M], добавлен 19.03.2015

  • Поняття об’єктно-орієнтовного програмування, поява відносин класів. Структури як складені типи даних, побудовані з використанням інших типів. Область дії класу і доступ до його елементів. Конструктор та деструктор класу. Розробка базового класу STRING.

    курсовая работа [280,9 K], добавлен 19.08.2010

  • Постановка лінійної цілочисленної задачі. Теоретичні основи методів відсікання. Задача з булевими змінними. Перший та другий алгоритми Гомори. Алгоритм Дальтона й Ллевелина. Поняття припустимого й оптимального рішення. Область пошуку екстремума.

    курсовая работа [187,8 K], добавлен 27.01.2011

  • Розробка програми перевірки логічного мислення людини на мові програмування С++, результатом якої є моделювання координатного переміщення. Визначення структури вхідних та вихідних даних, вибір мови програмування. Розгляд алгоритму рішення задачі.

    курсовая работа [55,8 K], добавлен 28.04.2015

  • Концепції об'єктно-орієнтованого програмування. Методи створення класів. Доступ до методів базового класу. Структура даних, функції. Розробка додатку на основі діалогових вікон, програми меню. Засоби розробки програмного забезпечення мовами Java та С++.

    курсовая работа [502,5 K], добавлен 01.04.2016

  • Розв’язок багатокритеріальної задачі лінійного програмування з отриманням компромісного рішення (для задач з кількома функціями мети) за допомогою теоретико-ігрового підходу. Матриця мір неоптимальності та рядок функції мети. Модуль опису класу.

    курсовая работа [588,8 K], добавлен 15.05.2011

  • Розробка програми на мові програмування С++ з використанням об'єктно-орієнтованого програмування. Робота з файлами, графікою, класами, обробка числової інформації. Графічні засоби мови програмування. Алгоритм задачі та допоміжні програмні засоби.

    курсовая работа [102,5 K], добавлен 14.03.2013

  • Розробка програми для вирішення графічної задачі. При вирішенні задачі необхідно cтворювати програму у середовищі програмування Turbo Pascal. Розробка алгоритму функціонування програми і надання блок-схеми алгоритму. Демонстрація роботи програми.

    курсовая работа [1,3 M], добавлен 23.06.2010

  • Розробка програми для моделювання роботи алгоритму Дейкстри мовою C# з використанням об’єктно-орієнтованих принципів програмування. Алгоритм побудови робочого поля. Програмування графічного інтерфейсу користувача. Тестування програмного забезпечення.

    курсовая работа [991,4 K], добавлен 06.08.2013

  • Основні розрахунки резисторів мікросхеми. Розробка алгоритму рішення задачі методом блок-схем. Характеристика та розробка програми на мові С++ з використанням принципів модульного і структурного програмування. План тестування і налагоджування програми.

    курсовая работа [2,9 M], добавлен 05.12.2012

  • Об'єктно-орієнтоване, або об'єктне, програмування. Поняття об'єктів і класів. Розробка програмного забезпечення. Створення операційних систем, прикладних програм, драйверів пристроїв, додатків для вбудованих систем, високопродуктивних серверів.

    контрольная работа [135,2 K], добавлен 25.10.2013

  • Сутність прикладної програми – класу, який містить процедуру main, в якому створюється вікно з кнопками управління. Аплет – пакет класу Java, який виконується різними прикладними програмами. Ініціалізація змінних та встановлення розміру вікна аплету.

    лабораторная работа [11,8 K], добавлен 09.06.2012

  • Програма на мові програмування С++. Аналіз стану технологій програмування та обґрунтування теми. Розробка програми виконання завдання, методу вирішення задачі. Робота з файлами, обробка числової інформації і робота з графікою. Розробка програми меню.

    курсовая работа [41,0 K], добавлен 17.02.2009

  • Розв’язання нелінійних алгебраїчних рівнянь методом дихотомії. Вирішення задачі знаходження коренів рівняння. Розробка алгоритму розв’язання задачі і тестового прикладу. Блок-схеми алгоритмів основних функцій. Інструкція користувача програмою мовою С++.

    курсовая работа [2,0 M], добавлен 24.09.2010

  • Загальний вид двовимірного завдання лінійного програмування. Алгоритм рішення задач графічним методом. Максимізація (мінімізація) цільової функції. Послідовність рішення завдань лінійного програмування симплексом-методом. Принцип перетворення Гауса.

    контрольная работа [149,8 K], добавлен 24.11.2010

  • Редагування за допомогою текстового редактора NotePad вхідного файлу даних. Програмна реалізація основного алгоритму з використанням засобів об'єктно-орієнтованого програмування. Об’ява та опис класів і об'єктів. Розробка допоміжних програмних засобів.

    курсовая работа [69,4 K], добавлен 14.03.2013

  • Програма "Приватка" для збереження та перегляду всієї інформації, що стосується пошуку підприємства. Розробка алгоритму та програмування на мові Turbo Pascal. Формальна та неформальна постановка задачі. Структура зберігаючих даних. Вихідний код програми.

    курсовая работа [20,9 K], добавлен 07.10.2010

  • Огляд та аналіз методів розв’язання системи диференціальних рівнянь та вибір методів рішення. Алгоритми методів Ейлера. Вибір методу рішення задачі Коші. Рішення диференціальних рівнянь. Отримання практичних навиків програмування на мові Паскаль.

    курсовая работа [174,3 K], добавлен 06.03.2010

Работы в архивах красиво оформлены согласно требованиям ВУЗов и содержат рисунки, диаграммы, формулы и т.д.
PPT, PPTX и PDF-файлы представлены только в архивах.
Рекомендуем скачать работу.