diff --git a/src/main/java/core/basesyntax/impl/StorageImpl.java b/src/main/java/core/basesyntax/impl/StorageImpl.java index 455a7b080..d12baf5fc 100644 --- a/src/main/java/core/basesyntax/impl/StorageImpl.java +++ b/src/main/java/core/basesyntax/impl/StorageImpl.java @@ -3,17 +3,54 @@ import core.basesyntax.Storage; public class StorageImpl implements Storage { + private static final int MAX_SIZE = 10; + private K[] keys; + private V[] values; + private int size; + + public StorageImpl() { + keys = (K[]) new Object[MAX_SIZE]; + values = (V[]) new Object[MAX_SIZE]; + size = 0; + } + @Override public void put(K key, V value) { + int index = findKey(key); + if (index != -1) { + values[index] = value; + return; + } + + if (size < MAX_SIZE) { + keys[size] = key; + values[size] = value; + size++; + } else { + throw new RuntimeException("Storage is full"); + } } @Override public V get(K key) { + int index = findKey(key); + if (index != -1) { + return values[index]; + } return null; } @Override public int size() { + return size; + } + + private int findKey(K key) { + for (int i = 0; i < size; i++) { + if (keys[i] == null && key == null || (keys[i] != null && keys[i].equals(key))) { + return i; + } + } return -1; } }