Мне кажется, что я запоминаю и удаляю из словаря все элементы по очереди. Во внутренним цикле сравниваю их с остальными, если совпадают, значит это повтор и нужно удалить. После внутреннего цикла я возвращаю один этот элемент и т.д.
package com.javarush.task.task08.task0817;
import java.util.HashMap;
import java.util.Map;
/*
Нам повторы не нужны
*/
public class Solution {
public static HashMap<String, String> createMap() {
HashMap<String, String> map = new HashMap<>();
map.put("1","hhugbh");
map.put("2","333");
map.put("3","345");
map.put("4","333");
map.put("5","123");
map.put("6","56754");
map.put("7","4353");
map.put("8","32");
map.put("9","123");
map.put("10","123");
return map;
}
public static void removeTheFirstNameDuplicates(Map<String, String> map) {
HashMap<String, String> copy = new HashMap<String, String>(map);
String name;
String fam;
for (Map.Entry<String, String> rair : copy.entrySet()){
name = rair.getValue();
fam = rair.getKey();
copy.remove(fam, name);
for (Map.Entry<String, String> raip : copy.entrySet()){
if(raip.getValue().equals(name))
removeItemFromMapByValue(map, name);
}
copy.put(fam, name);
}
}
public static void removeItemFromMapByValue(Map<String, String> map, String value) {
HashMap<String, String> copy = new HashMap<String, String>(map);
for (Map.Entry<String, String> pair : copy.entrySet()) {
if (pair.getValue().equals(value))
map.remove(pair.getKey());
}
}
public static void main(String[] args) {
}
}