дженерики
и
структуры

дженерики

Структуры данных

Динамический массив

public class DynamicArray {
    int[] data;
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        list.add(1);
        list.add(2);
        list.add(3);
        System.out.println(list);
    }
}

>>> [1, 2, 3]

Динамический массив

public class DynamicArray {
    int[] data;
    
    public void add(int element) {
        // тут как то должны добавляться элементы
    }    
}

Куда-то надо добавлять элементы, а массив пустой

Можно попробовать создать внутри массив ограниченного размера

Динамический массив

public class DynamicArray {
    int[] data;
    
    public void add(int element) {
        // тут как то должны добавляться элементы
    }    
}

Куда-то надо добавлять элементы, а массив пустой

Можно попробовать создать внутри массив ограниченного размера

Динамический массив

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // тут как то должны добавляться элементы
    }    
}

Динамический массив

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // положили элемент в край динамического списка
        data[size] = element; 
        // сдвинули правый край списка
        size += 1;
    }
}

Динамический массив

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // положили элемент в край динамического списка
        data[size] = element; 
        // сдвинули правый край списка
        size += 1;
    }
}

el1

el2

el3

el4

Динамический массив

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // положили элемент в край динамического списка
        data[size] = element; 
        // сдвинули правый край списка
        size += 1;
    }
}

el1

el2

el3

el4

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // положили элемент в край динамического списка
        data[size] = element; 
        // сдвинули правый край списка
        size += 1;
    }
}

el1

el2

el3

el4

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // положили элемент в край динамического списка
        data[size] = element; 
        // сдвинули правый край списка
        size += 1;
    }
}

el1

el2

el3

el4

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // положили элемент в край динамического списка
        data[size] = element; 
        // сдвинули правый край списка
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // положили элемент в край динамического списка
        data[size] = element; 
        // сдвинули правый край списка
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        // чего сделать надо?
        data[size] = element;
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        if (size >= data.length) {
            // ...
        }
        data[size] = element;
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
        }
        data[size] = element;
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                // ...
            }
        }
        data[size] = element;
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
        }
        data[size] = element;
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            // ???
        }
        data[size] = element;
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }
}

el1

el2

el3

public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }
}
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }
    
    @Override
    public String toString() {
        return Arrays.toString(data);
    }    
}
public class Main {
    public static void main(String[] args) {
        // ...
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        for (int i = 0; i < 10; ++i) {
            list.add(i);
        }        
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        for (int i = 0; i < 10; ++i) {
            list.add(i);
        }        
        System.out.println(list);        
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        for (int i = 0; i < 10; ++i) {
            list.add(i);
        }        
        System.out.println(list);        
    }
}


>>> [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 0]
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() {
        return Arrays.toString(data);
    }    
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        for (int i = 0; i < 10; ++i) {
            list.add(i);
        }        
        System.out.println(list);        
    }
}


>>> [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 0]
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() {
    	int[] subArray = Arrays.copyOfRange(data, 0, size);
        return Arrays.toString(subArray);
    }    
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        for (int i = 0; i < 10; ++i) {
            list.add(i);
        }        
        System.out.println(list);        
    }
}


>>> [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 0]
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() {
    	int[] subArray = Arrays.copyOfRange(data, 0, size);
        return Arrays.toString(subArray);
    }    
}
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() {
    	int[] subArray = Arrays.copyOfRange(data, 0, size);
        return Arrays.toString(subArray);
    }    
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        for (int i = 0; i < 10; ++i) {
            list.add(i);
        }
        System.out.println(list);
    }
}
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() {
    	int[] subArray = Arrays.copyOfRange(data, 0, size);
        return Arrays.toString(subArray);
    }    
}
public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        for (int i = 0; i < 10; ++i) {
            list.add(i);
        }
        System.out.println(list);
    }
}

>>> [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() { /* ... */ }    
}
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() { /* ... */ }    
    
    // метод который возвращает элемент
    public ??? at(int index) {
    	// ...
    }    
}
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() { /* ... */ }    
    
    // метод который возвращает элемент
    public int at(int index) {
    	// ...
    }    
}
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() { /* ... */ }    
    
    // метод который возвращает элемент
    public int at(int index) {
    	return data[index];
    }    
}
public class DynamicArray {
    int [] data = new int[3];
    int size = 0;
    
    public void add(int element) { /* ... */ }
    
    @Override
    public String toString() { /* ... */ }    
    
    // метод который возвращает элемент
    public int at(int index) {
    	if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
    	return data[index];
    }    
}

Нажал Alt+Insert

public class DynamicArray {
    int[] data = new int[3];
    int size = 0;

    public int getSize() {
        return size;
    }

    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public int at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() {
        int[] subArray = Arrays.copyOfRange(data, 0, size);
        return Arrays.toString(subArray);
    }
}

ArrayList

public class Main {
    public static void main(String[] args) {
        DynamicArray list = new DynamicArray();
        for (int i = 0; i < 10; ++i) {
            list.add(i);
        }
        System.out.println(list);
    }
}

>>> [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
public class Main {
    public static void main(String[] args) {
        ArrayList<Integer> arrayList = new ArrayList<>();
        for (int i = 0; i < 10; ++i) {
            arrayList.add(i);
        }
        System.out.println(arrayList);
    }
}

>>> [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
public class DynamicArray {
    int[] data = new int[3];
    int size = 0;

    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public int at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class DynamicArray <T> {
    int[] data = new int[3];
    int size = 0;

    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public int at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class DynamicArray <T> {
    T[] data = new T[3];
    int size = 0;

    public void add(int element) {
        if (size >= data.length) {
            int[] newData = new int[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public int at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class DynamicArray <T> {
    T[] data = new T[3];
    int size = 0;

    public void add(T element) {
        if (size >= data.length) {
            T[] newData = new T[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public int at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class DynamicArray <T> {
    T[] data = new T[3];
    int size = 0;

    public void add(T element) {
        if (size >= data.length) {
            T[] newData = new T[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public T at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class DynamicArray <T> {
    T[] data = new T[3];
    int size = 0;

    public void add(T element) {
        if (size >= data.length) {
            T[] newData = new T[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public T at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
  • Нельзя вызывать  new  потому что нет гарантии что у  T  есть конструктор без параметров
  • Поэтому надо вместо T при инициализации использовать Object
  • По сути можно рассматривать Object как просто ссылку на область памяти
  • Почти все объекты в Java наследуются от Object
public class DynamicArray <T> {
    T[] data = new T[3];
    int size = 0;

    public void add(T element) {
        if (size >= data.length) {
            T[] newData = new T[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public T at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class DynamicArray <T> {
    Object[] data = new Object[3];
    int size = 0;

    public void add(T element) {
        if (size >= data.length) {
            T[] newData = new T[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public T at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class DynamicArray <T> {
    Object[] data = new Object[3];
    int size = 0;

    public void add(T element) {
        if (size >= data.length) {
            Object[] newData = new Object[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public T at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class DynamicArray <T> {
    Object[] data = new Object[3];
    int size = 0;

    public void add(T element) {
        if (size >= data.length) {
            Object[] newData = new Object[data.length * 2];
            for (int i = 0; i < data.length; ++i) {
                newData[i] = data[i];
            }
            this.data = newData;
        }
        data[size] = element;
        size += 1;
    }

    public T at(int index) {
        if (index >= size) {
            throw new ArrayIndexOutOfBoundsException();
        }
        return (T) data[index];
    }

    @Override
    public String toString() { /*...*/ }
    public int getSize() { return size; }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<int> list = new DynamicArray<>();
    }
}

Нельзя использовать примитивные типы
int, boolean, double etc.

Надо использовать ссылочные типы
Integer, Boolean, Double etc.

public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> list = new DynamicArray<>();
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> list = new DynamicArray<>();
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<String> list = new DynamicArray<>();
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<String> list = new DynamicArray<>();
        list.add("В");
        list.add("лесу");
        list.add("родилась");
        list.add("елочка");        
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<String> list = new DynamicArray<>();
        list.add("В");
        list.add("лесу");
        list.add("родилась");
        list.add("елочка");        
        System.out.println(list);
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<String> list = new DynamicArray<>();
        list.add("В");
        list.add("лесу");
        list.add("родилась");
        list.add("елочка");        
        System.out.println(list);
    }
}


>>> [В, лесу, родилась, елочка]

Множество

Множество

el1

el2

el3

el3

Множество

el1

el2

el3

el3

Множество

el1

el2

el3

el4

Множество

el1

el2

el3

el4

Хранит только уникальные элементы

public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> a = new DynamicArray<>();
        a.add(1);
        a.add(2);
        a.add(1);
        System.out.println(a.getSize());
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> a = new DynamicArray<>();
        a.add(1);
        a.add(2);
        a.add(1);
        System.out.println(a.getSize());
    }
}

>>> 3
public class Main {
    public static void main(String[] args) {
        DynamicSet<Integer> a = new DynamicSet<>();
        a.add(1);
        a.add(2);
        a.add(1);
        System.out.println(a.getSize());
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicSet<Integer> a = new DynamicSet<>();
        a.add(1);
        a.add(2);
        a.add(1);
        System.out.println(a.getSize());
    }
}

>> 2
public class DynamicSet {
}
public class DynamicSet extends DynamicArray {
}
public class DynamicSet<T> extends DynamicArray<T> {
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(/* ??? */) {
        // Работать должен по принципу:
        // если элемент есть то возвращаем его индекс
        // если элемента нет то возвращаем -1
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        // Работать должен по принципу:
        // если элемент есть то возвращаем его индекс
        // если элемента нет то возвращаем -1
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < ???; ++i) {
        	
        }
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < [size или data.length() ???]; ++i) {
        	
        }
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
        	
        }
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i] == value) {
            	//...
            }
        }
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i] == value) {
            	return i;
            }
        }
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i] == value) {
            	return i;
            }
        }
        return -1;
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i].equals(value)) {
            	return i;
            }
        }
        return -1;
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i].equals(value)) {
            	return i;
            }
        }
        return -1;
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i].equals(value)) {
            	return i;
            }
        }
        return -1;
    }
}

Жмем Ctrl + O

public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i].equals(value)) {
            	return i;
            }
        }
        return -1;
    }
    
    @Override
    public void add(T element) {
        super.add(element);
    }
}

Жмем Ctrl + O

public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i].equals(value)) {
            	return i;
            }
        }
        return -1;
    }
    
    @Override
    public void add(T element) {
    	if (???) {
            super.add(element);
        }
    }
}
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i].equals(value)) {
            	return i;
            }
        }
        return -1;
    }
    
    @Override
    public void add(T element) {
    	if (indexOf(element) == -1) {
    	    super.add(element);
        }
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicSet<String> a = new DynamicSet<>();
        a.add("Ура!");
        a.add("Ура!");
        a.add("Ура!");
        System.out.println(a.getSize());
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicSet<String> a = new DynamicSet<>();
        a.add("Ура!");
        a.add("Ура!");
        a.add("Ура!");
        System.out.println(a.getSize());
    }
}

>>> 1
public class Main {
    public static void main(String[] args) {
        HashSet<String> a = new HashSet<>();
        a.add("Ура!");
        a.add("Ура!");
        a.add("Ура!");
        System.out.println(a.size());
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicSet<String> a = new DynamicSet<>();
        a.add("Ура!");
        a.add("Ура!");
        a.add("Ура!");
        System.out.println(a.getSize());
    }
}

>>> 1
public class Main {
    public static void main(String[] args) {
        HashSet<String> a = new HashSet<>();
        a.add("Ура!");
        a.add("Ура!");
        a.add("Ура!");
        System.out.println(a.size());
    }
}

>>> 1

Задача:
Подсчитать сколько уникальных символов в предложении

public class Main {
    public static void main(String[] args) {
        String text = "мама мыла раму";
    }
}

Задача:
Подсчитать сколько уникальных символов в предложении

public class Main {
    public static void main(String[] args) {
        String text = "мама мыла раму";
        
        DynamicSet<???> a = new DynamicSet<>();
    }
}

Задача:
Подсчитать сколько уникальных символов в предложении

public class Main {
    public static void main(String[] args) {
        String text = "мама мыла раму";
        
        DynamicSet<Character> a = new DynamicSet<>();
    }
}

Задача:
Подсчитать сколько уникальных символов в предложении

public class Main {
    public static void main(String[] args) {
        String text = "мама мыла раму";
        
        DynamicSet<Character> a = new DynamicSet<>();
        
        for(Character c : text.toCharArray()) {
            // ???
        }
    }
}

Задача:
Подсчитать сколько уникальных символов в предложении

public class Main {
    public static void main(String[] args) {
        String text = "мама мыла раму";
        
        DynamicSet<Character> a = new DynamicSet<>();
        
        for(Character c : text.toCharArray()) {
            a.add(c);
        }
    }
}

Задача:
Подсчитать сколько уникальных символов в предложении

public class Main {
    public static void main(String[] args) {
        String text = "мама мыла раму";
        
        DynamicSet<Character> a = new DynamicSet<>();
        
        for(Character c : text.toCharArray()) {
            a.add(c);
        }
        
        System.out.println(a.getSize());
    }
}

Словарик

ключи все разные

значения могут повторяться

ключ 1

ключ 2

ключ 3

...

значение 1

значение 2

значение 3

...

Гистограмма

ключи по X

значения по y

сентябрь

ноябрь

октябрь

декабрь

60

50

40

55

public class DynamicDict {
	
}

июнь

июль

август

10

20

5

ключи

значения

public class DynamicDict {
    DynamicSet<???> keys = new DynamicSet<>();
}

июнь

июль

август

10

20

5

ключи

значения

public class DynamicDict {
    DynamicSet<String> keys = new DynamicSet<>();
}

июнь

июль

август

10

20

5

ключи

значения

public class DynamicDict {
    DynamicSet<String> keys = new DynamicSet<>();
    DynamicSet<Integer> values = new DynamicSet<>();
}

июнь

июль

август

10

20

5

ключи

значения

public class DynamicDict {
    DynamicSet<String> keys = new DynamicSet<>();
    DynamicSet<Integer> values = new DynamicSet<>();
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict {
    DynamicSet<String> keys = new DynamicSet<>();
    DynamicArray<Integer> values = new DynamicArray<>();
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<String> keys = new DynamicSet<>();
    DynamicArray<Integer> values = new DynamicArray<>();
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(???) {
        
    }
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(??? key, ??? value) {
        
    }
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        
    }
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
    }
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            // ???    
        }
    }
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        }
    }
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public ??? get(???) {

    }    
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public V get(K key) {

    }    
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public V get(K key) {
        int iKey = keys.indexOf(key);
    }    
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public V get(K key) {
        int iKey = keys.indexOf(key);
        if (iKey != -1) {
            // ???
        }        
    }    
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public V get(K key) {
        int iKey = keys.indexOf(key);
        if (iKey != -1) {
            return values.at(iKey);
        }        
    }    
}

июнь

июль

август

10

20

10

ключи

значения

public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void put(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public V get(K key) {
        int iKey = keys.indexOf(key);
        if (iKey != -1) {
            return values.at(iKey);
        }
        return null;
    }    
}

июнь

июль

август

10

20

10

ключи

значения

String text = "мама мыла раму";

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {

}

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// ???        
    }
}

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
    }
}

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
        dict.put(c, 1);
    }
}

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
        dict.put(c, 1);
    } else {
    	// надо увеличить значение ключа на единицу
    }
}

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
        dict.put(c, 1);
    } else {
    	// надо увеличить значение ключа на единицу
        int value = dict.get(c);
    }
}

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
        dict.put(c, 1);
    } else {
    	// надо увеличить значение ключа на единицу
        int value = dict.get(c);
        dict.put(c, value + 1);
    }
}

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
        dict.put(c, 1);
    } else {
    	// надо увеличить значение ключа на единицу
        int value = dict.get(c);
        dict.put(c, value + 1);
    }
}

System.out.println(dict);

Задача:
Подсчитать сколько какая буква встречается в предложении

String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
        dict.set(c, 1);
    } else {
    	// надо увеличить значение ключа на единицу
        int value = dict.get(c);
        dict.set(c, value + 1);
    }
}

System.out.println(dict);

Задача:
Подсчитать сколько какая буква встречается в предложении

м: 4
а: 4
 : 2
ы: 1
л: 1
р: 1
у: 1
String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
        dict.put(c, 1);
    } else {
    	// надо увеличить значение ключа на единицу
        int value = dict.get(c);
        dict.put(c, value + 1);
    }
}

System.out.println(dict);
String text = "мама мыла раму";

HashMap<Character, Integer> dict = new HashMap<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
        // если элемент не найден, то положил по ключу "c" значение 1
        dict.put(c, 1);
    } else {
        // надо увеличить значение ключа на единицу
        int value = dict.get(c);
        dict.put(c, value + 1);
    }
}

System.out.println(dict);

Задача:
Подсчитать сколько какая буква встречается в предложении

м: 4
а: 4
 : 2
ы: 1
л: 1
р: 1
у: 1
String text = "мама мыла раму";

DynamicDict<Character, Integer> dict = new DynamicDict<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
    	// если элемент не найден, то положил по ключу "c" значение 1
        dict.set(c, 1);
    } else {
    	// надо увеличить значение ключа на единицу
        int value = dict.get(c);
        dict.set(c, value + 1);
    }
}

System.out.println(dict);
String text = "мама мыла раму";

HashMap<Character, Integer> dict = new HashMap<>();

for(Character c : text.toCharArray()) {
    if(dict.get(c) == null) {
        // если элемент не найден, то положил по ключу "c" значение 1
        dict.put(c, 1);
    } else {
        // надо увеличить значение ключа на единицу
        int value = dict.get(c);
        dict.put(c, value + 1);
    }
}

System.out.println(dict);

Специализация дженериков

public class DynamicArray <T> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public ??? Max() {
        
    }    
}
public class DynamicArray <T> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        
    }    
}
public class DynamicArray <T> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0];        
    }    
}
public class DynamicArray <T> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            // ???   
        }
    }    
}
public class DynamicArray <T> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            if (el > max) {
                max = el;
            }
        }
    }    
}
public class DynamicArray <T> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            if (el > max) {
                max = el;
            }
        }
        return max;
    }    
}
public class DynamicArray <T> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            if (el > max) {
                max = el;
            }
        }
        return max;
    }    
}
public class DynamicArray <T extends Comparable> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            if (el > max) {
                max = el;
            }
        }
        return max;
    }    
}
public interface Comparable<T> {
     public int compareTo(T other);
}

-1 если this меньше оther

0 если this равен other

1 если this больше other

public class DynamicArray <T extends Comparable> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            if (el > max) {
                max = el;
            }
        }
        return max;
    }    
}
public interface Comparable<T> {
     public int compareTo(T other);
}

-1 если this меньше оther

0 если this равен other

1 если this больше other

public class DynamicArray <T extends Comparable> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            if (el.compareTo(max) ???) {
                max = el;
            }
        }
        return max;
    }    
}
public class DynamicArray <T extends Comparable> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            if (el.compareTo(max) == 1) {
                max = el;
            }
        }
        return max;
    }    
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> array = new DynamicArray<>();
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> array = new DynamicArray<>();
        array.add(3);
        array.add(2);
        array.add(5);
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> array = new DynamicArray<>();
        array.add(3);
        array.add(2);
        array.add(5);
        System.out.println(array.Max());        
    }
}
public class DynamicArray <T extends Comparable> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(T el : (T[]) data) {
            if (el.compareTo(max) == 1) {
                max = el;
            }
        }
        return max;
    }    
}
public class DynamicArray <T extends Comparable> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(Object obj : data) {
            if (el.compareTo(max) == 1) {
                max = el;
            }
        }
        return max;
    }    
}
public class DynamicArray <T extends Comparable> {
    public Object[] data = new Object[3];
    int size = 0;

    public int getSize() { /*...*/ }

    public void add(T element) { /* ... */ }

    public T at(int index) { /* ... */ }

    @Override
    public String toString() { /* ... */ }
    
    public T Max() {
        T max = (T) data[0]; 
        for(Object obj : data) {
            T el = (T) obj;
            if (el.compareTo(max) == 1) {
                max = el;
            }
        }
        return max;
    }    
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> array = new DynamicArray<>();
        array.add(3);
        array.add(2);
        array.add(5);
        System.out.println(array.Max());        
    }
}
public class Main {
    public static void main(String[] args) {
        DynamicArray<Integer> array = new DynamicArray<>();
        array.add(3);
        array.add(2);
        array.add(5);
        System.out.println(array.Max());        
    }
}


>>> 5
public class DynamicSet<T> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i].equals(value)) {
            	return i;
            }
        }
        return -1;
    }
    
    @Override
    public void add(T element) {
    	if (indexOf(element) == -1) {
    	    super.add(element);
        }
    }
}
public class DynamicSet<T extends Comparable<T>> extends DynamicArray<T> {
    public int indexOf(T value) {
        for (int i = 0;i < size; ++i) {
            if (data[i].equals(value)) {
            	return i;
            }
        }
        return -1;
    }
    
    @Override
    public void add(T element) {
    	if (indexOf(element) == -1) {
    	    super.add(element);
        }
    }
}
public class DynamicDict <K, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void set(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public V get(K key) {
        int iKey = keys.indexOf(key);
        if (iKey != -1) {
            return values.at(iKey);
        }
        return null;
    }    
}
public class DynamicDict <K extends Comparable<K>, V> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void set(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public V get(K key) {
        int iKey = keys.indexOf(key);
        if (iKey != -1) {
            return values.at(iKey);
        }
        return null;
    }    
}
public class DynamicDict <K extends Comparable<K>, V extends Comparable<V>> {
    DynamicSet<K> keys = new DynamicSet<>();
    DynamicArray<V> values = new DynamicArray<>();
    
    // метод который присваивает значение ключу
    public void set(K key, V value) {
        int iKey = keys.indexOf(key);
        if (iKey == -1) {
            keys.add(key);
            values.add(value);
        } else {
            values.data[iKey] = value;
        }
    }
    
    // метод который возвращает значение по ключу
    public V get(K key) {
        int iKey = keys.indexOf(key);
        if (iKey != -1) {
            return values.at(iKey);
        }
        return null;
    }    
}

Мини контра

/* даны две функции */

public static int CalculateAdd(ArrayList<Integer> list) {
    int result = 0;
    for (int el : list) {
        if (el % 2 == 1) {
            result = result + el;
        }
    }
    return result;
}

public static int CalculateSub(ArrayList<Integer> list) {
    int result = 0;
    for (int el : list) {
        if (el % 2 == 0) {
            result = result - el;
        }
    }
    return result;
}

попытка вторая

Используя Function и BiFunction сделать из них одну универсальную. С помощью лямбда выражений вызвать новую функцию два раза так,

  • чтобы первый раз она сработала как CalculateAdd
  • а второй раз как CalculateSub

GENERICS

By Mikhail K.

GENERICS

  • 271