using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Catamaran { /// /// Параметризованный набор объектов /// /// internal class SetBoatsGeneric where T : class, IEquatable { /// /// Массив объектов, которые храним /// private readonly List _places; /// /// Количество объектов в массиве /// public int Count => _places.Count; private readonly int _maxCount; /// /// Конструктор /// /// public SetBoatsGeneric(int count) { _maxCount = count; _places = new List(); } /// /// Добавление объекта в набор /// /// Добавляемая лодка /// public int Insert(T boat) { return Insert(boat, 0); } /// /// Добавление объекта в набор на конкретную позицию /// /// Добавляемая лодка /// Позиция /// public int Insert(T boat, int position) { // TODO проверка на уникальность // проверка позиции if (position < 0 || position >= _maxCount) { return -1 ; } // проверка, что элемент массива по этой позиции пустой,если нет, то // проверка, что после вставляемого элемента в массиве есть пустой элемент // сдвиг всех объектов, находящихся справа от позиции до первого пустого элемента if (position == Count) { _places.Insert(position, boat); return position; } else { for (int i = position + 1; i < _maxCount; i++) { if (i == Count) { for (int j = i - 1; j >= position; j--) { _places[j + 1] = _places[j]; } _places.Insert(position, boat); return position; } } throw new StorageOverflowException(_maxCount); } // вставка по позиции } /// /// Удаление объекта из набора с конкретной позиции /// /// /// public T Remove(int position) { // проверка позиции if (position < 0 || position >= Count) throw new BoatNotFoundException(); // удаление объекта из массива, присовив элементу массива значение null var result = _places[position]; _places.RemoveAt(position); return result; } /// /// Получение объекта из набора по позиции /// /// /// public T this[int position] { // проверка позиции get { if (position >= 0 && position < _maxCount && position < Count) { return _places[position]; } else { return null; } } set { if (position > 0 || position < Count) { Insert(value, position); } } } /// /// Проход по набору до первого пустого /// /// public IEnumerable GetBoats() { foreach (var boat in _places) { if (boat != null) { yield return boat; } else { yield break; } } } /// /// Сортировка набора объектов /// /// public void SortSet(IComparer comparer) { if (comparer == null) { return; } _places.Sort(comparer); } } }