немного примитивно написал код программы, но более сложные конструкции у меня не проходили по работе кода (пытался напрямую работать с листом, но не зашло). В итоге добился верного (на мой взгляд) выполнения работы, но валидатор не принял выдав отказ по пункту заполнения мапы. Подтолкнёте в нужном векторе ?
Может кто покажет какими данными лучше протестировать этот код ?
package com.javarush.task.task10.task1016;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
/*
Одинаковые слова в списке
*/
public class Solution {
public static void main(String[] args) throws Exception {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
ArrayList<String> words = new ArrayList<String>();
for (int i = 0; i < 20; i++) {
words.add(reader.readLine());
}
Map<String, Integer> map = countWords(words);
for (Map.Entry<String, Integer> pair : map.entrySet()) {
System.out.println(pair.getKey() + " " + pair.getValue());
}
}
public static Map<String, Integer> countWords(ArrayList<String> list) {
HashMap<String, Integer> result = new HashMap<String, Integer>();
//напишите тут ваш код
int[] word_count = new int[20];
String[] tmp = new String[list.size()];
for (int a=0;a<list.size();a++)
tmp[a]=list.get(a);
for (int a=0;a<list.size();a++)
{
String folder = tmp[a];
for (int b=0;b<list.size();b++)
if (tmp[b].equals(folder))
word_count[b]++;
}
for (int a=0;a< list.size();a++)
if (word_count[a]>1)
result.put(tmp[a],word_count[a]-1);
return result;
}
}