Требования к выполнению задания:
- Не нужно работать с БД
- Применить принципы объектно-ориентированного программирования, а так же шаблоны проектирования
- Использовать свои классы коллекций MyLinkedList или MyArrayList
- Во время реализации подумайте, насколько легко в вашу систему будет добавить новый тип карты или изменить существующий (чем в большее число мест кода нужно вносить изменений, тем архитектура хуже)
- Реализовать тесты.
Варианты заданий (реализовать один из вариантов): Вариант 1. Реализовать набор классов, которые моделирует работу системы ski-pass. Турникет контролирует вход лыжников на подъемник по ski-pass. Ski-pass бывают следующих видов:
- На рабочие дни: a. Без учета количества подъемов: на полдня (с 9 до 13 или с 13 до 17), на день, два дня, 5 дней. b. По количеству подъемов: на 10 подъемов, на 20 подъемов, на 50 подъемов, на 100 подъемов.
- На выходные дни: a. Без учета количества поездок: на полдня (с 9 до 13 или с 13 до 17), на день, два дня. b. По количеству подъемов: на 10 подъемов, на 20 подъемов, на 50 подъемов, на 100 подъемов.
- Абонемент на сезон. Турникет должен быть связан с системой, в который ведется реестр выданных карточек. В этой системе возможно:
- выпустить ski-pass;
- заблокировать ski-pass из-за нарушения правил подъема. Данные по карточки хранятся на самой карте, а именно: уникальный идентификатор, тип карты, срок действия, количество поездок и т.д. Турникет считывает данные с карты и выполняет ее проверку. Если данные не удалось считать, или карточка просрочена, или заблокирована, или на ней не осталось кредитов для поездок, то проход запрещен. Иначе с карточки снимается одна поездка (если для карты предполагается учет подъемов) и проход разрешается. Система так же осуществляет учет разрешений и отказов прохода. И умеет выдавать по запросу 1) суммарные данные и 2) данные разбиты по типам ski-pass.