В примере специально сделал, чтобы было два человека с максимальным значением, однако при переборе TreeMap выводится на печать всего лишь одно первое совпадение, подскажите пожалуйста почему такое поведение?
Например в этом случае
Петров 0.50
Иванов 1.35
Петров 0.85
Выводится только Иванов...package com.javarush.task.task19.task1920;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Map;
import java.util.TreeMap;
import java.util.TreeSet;
/*
Самый богатый
*/
public class Solution {
public static void main(String[] args) throws IOException{
BufferedReader br = new BufferedReader(new FileReader(args[0]));
String str;
TreeMap<String,Double> tree = new TreeMap<>();
while (br.ready()){
str = br.readLine();
String[] array = str.split(" ");
tree.merge(array[0],Double.parseDouble(array[1]), Double::sum);
}
Double max = 0.0;
for (Map.Entry<String,Double> entry : tree.entrySet()){
if (max < entry.getValue()) {max = entry.getValue();}
System.out.println(entry.getKey() + " " + entry.getValue());
}
for (String s: tree.keySet()){
if (max == tree.get(s)) {
System.out.println(s);
}
}
br.close();
}
}
/*
Самый богатый
В метод main первым параметром приходит имя файла.
В этом файле каждая строка имеет следующий вид:
имя значение
где [имя] - String, [значение] - double. [имя] и [значение] разделены пробелом.
Для каждого имени посчитать сумму всех его значений.
Вывести в консоль имена в алфавитном порядке, у которых максимальная сумма.
Имена разделять пробелом либо выводить с новой строки.
Закрыть потоки.
Пример входного файла:
Петров 0.501
Иванов 1.35
Петров 0.85
Пример вывода:
Петров
Requirements:
1. Программа НЕ должна считывать данные с консоли.
2. Программа должна считывать содержимое файла (используй FileReader).
3. Поток чтения из файла (FileReader) должен быть закрыт.
4. Программа должна выводить в консоль имена, у которых максимальная сумма.*/