PIbd-14_Pruidze_I.K_Simple_.../ProjectCruiser/CollectionGenericObj/ArrayGenObj.cs

118 lines
2.6 KiB
C#
Raw Normal View History

2024-06-15 13:28:42 +04:00

namespace ProjectCruiser.CollectionGenericObj;
public class ArrayGenObj<T> : ICollectionGenObj<T>
where T : class
{
// Массив объектов, которые храним
private T?[] _collection;
2024-06-15 18:06:35 +04:00
// Максимально допустимое число объектов в массиве
private int _maxCount;
public int Count => _collection.Count(s => s != null);
2024-06-15 13:28:42 +04:00
public int MaxCount
{
2024-06-15 18:06:35 +04:00
get { return _maxCount; }
2024-06-15 09:05:36 +04:00
set
{
if (value > 0)
{
2024-06-15 18:06:35 +04:00
if (_collection.Length == 0) _collection = new T?[value];
else Array.Resize(ref _collection, value);
_maxCount = value;
}
}
}
2024-06-15 13:28:42 +04:00
public CollectionType GetCollectionType => CollectionType.Array;
public ArrayGenObj()
{
_collection = Array.Empty<T?>();
}
// methods :
public T? GetItem(int index)
{
if (index > Count || index < 0)
{
return null;
}
return _collection[index];
}
public int Insert(T? item)
{
2024-06-15 18:06:35 +04:00
if (Count >= _maxCount || item == null)
{
return -1;
}
// any empty place -> fill immediately
for (int i = 0; i < _collection.Length; i++)
{
if (_collection[i] == null)
{
_collection[i] = item;
return i;
}
}
2024-06-15 18:06:35 +04:00
return Count;
}
public int Insert(T? item, int index)
{
2024-06-15 18:06:35 +04:00
if (index >= _maxCount || Count >= _maxCount ||
index < 0 || _collection[index] != null
|| item == null)
{
return -1;
}
if (_collection[index] == null)
{
_collection[index] = item;
return index;
}
2024-06-15 18:06:35 +04:00
int min_diff = 100, firstNullIndex = 100;
2024-06-15 18:06:35 +04:00
for (int i = 0; i < Count; i++)
{
if (_collection[i] == null
&& min_diff > Math.Abs(index - i))
{
2024-06-15 18:06:35 +04:00
min_diff = Math.Abs(index - i);
firstNullIndex = i;
}
}
2024-06-15 18:06:35 +04:00
_collection[firstNullIndex] = item;
return firstNullIndex;
}
public T? Remove(int index)
{
2024-06-15 18:06:35 +04:00
if (index >= Count || index < 0)
// on the other positions items don't exist
{
2024-06-15 18:06:35 +04:00
return null;
}
2024-06-15 18:06:35 +04:00
T? item = _collection[index];
_collection[index] = null;
return item;
}
2024-06-15 13:28:42 +04:00
public IEnumerable<T?> GetItems()
{
2024-06-15 18:06:35 +04:00
for (int i = 0; i < MaxCount; ++i)
2024-06-15 13:28:42 +04:00
{
yield return _collection[i];
}
}
}