Все условия задачи выполнены, кроме этого: Должно быть обеспечено корректное поведение HashSet с типом элементов Solution.
Что тут имеется ввиду?
package com.javarush.task.jdk13.task21.task2101;
import java.util.HashSet;
import java.util.Objects;
import java.util.Set;
/*
Equals and HashCode
*/
public class Solution {
private final String first;
private final String last;
public Solution(String first, String last) {
this.first = first;
this.last = last;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof Solution)) return false;
Solution solution = (Solution) o;
return Objects.equals(first, solution.first) && Objects.equals(last, solution.last);
}
public int hashCode() {
return 31 * first.hashCode() + last.hashCode();
}
public static void main(String[] args) {
Set<Solution> s = new HashSet<>();
s.add(new Solution("Donald", "Duck"));
System.out.println(s.contains(new Solution("Donald", "Duck1")));
}
}