你好,
我有不合逻辑的字符串列表,例如:
Scanner s = new Scanner(
"m29 523\n" +
"b34 827\n" +
"p42 235\n" +
"b34 294\n" +
"t78 421\n" +
"t78 673\n" +
"c93 173\n" +
"k46 925\n" +
"k46 322\n" +
"x21 644\n");
然后我想将字符串分成两部分 - 在空格之前和之后,消除重复并在重复(b34,t78,k46)中只留下最大值(空格之后)。我的意思是这样的输出:
"m29 523"
"b34 827"
"p42 235"
"t78 673"
"c93 173"
"k46 925"
"x21 644"
至于分成两部分并消除重复我使用这样的代码,这对我来说没问题:
Map<String, ArrayList<String>> list = new HashMap<String, ArrayList<String>>();
while (s.hasNext()){
String key = s.next();
if(!list.containsKey(key));
list.put(key, new ArrayList<String>());
list.get(key).add(s.next());
}
System.out.println(list);
但是不明白我如何在这里实现字符串第二部分的比较以获得最大值?Integer.parseInt(list.get(key))?