题目要求
输入一行数据,格式如下:
1
| (abc,1),(123,2),(ddd,1),(abc,1)
|
每一组数据(String, int)形式,左边为字符串,右边为优先级,将这一行数据按优先级从大到小排列,并且过滤掉字符串与优先级相同的数据, 相同优先级、字符串不同的按先后顺序显示,排列后结果如下:
分析题意
我最开始的想法是:
- 用正则表达式将字符串中的键值对提取出来;
- 将提取出来的键值对放到List<Map>中;
- 遍历List进行排序;
但是真正开始写的时候第一步就卡住了,写出来的正则表达式只能提取最左边左括号到最右边右括号的内容,就是一整个字符串全给提取出来了,卡了半小时没办法,放弃了正则表达式的做法,改成了遍历 + split() 的方法。
拆分之后仔细想想,建一个实体类并且实现Comparable接口好像更简便一些,同时重写 hashCode() 方法和 equals() 方法再利用 Set 还能达到去重的效果,可以满足题目的要求。
代码实现
感觉代码有点又臭又长,明天再看下网上有没有这个题目,看看更标准的答案。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
| package com.test;
import java.util.*;
public class MediumMain { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); while (scanner.hasNext()) { String line = scanner.nextLine(); List<Entity> list = sort(line); System.out.println(list); } }
private static List<Entity> sort(String inputLine) { String[] split1 = inputLine.split("\\),\\("); Set<Entity> set = new HashSet<>(); for (int i = 0; i < split1.length; i++) { String[] split2 = split1[i].split(","); String str; int priority; if (i == 0) { str = split2[0].substring(1); } else { str = split2[0]; } if (i == split1.length - 1) { priority = Integer.parseInt(split2[1].split("\\)")[0]); } else { priority = Integer.parseInt(split2[1]); } Entity entity = new Entity(str, priority); set.add(entity); } List<Entity> list = new ArrayList<>(set); list.sort(Comparator.naturalOrder()); return list; } }
class Entity implements Comparable<Entity> { private String str; private Integer priority;
public Entity(String str, Integer priority) { this.str = str; this.priority = priority; }
@Override public int hashCode() { return str.hashCode() * priority.hashCode(); }
@Override public boolean equals(Object obj) { if (obj == null) { return false; } else if (this == obj) { return true; } else if (obj instanceof Entity) { Entity entity = (Entity) obj; return entity.getPriority() == this.getPriority() && entity.getStr().equals(this.getStr()); } return false; }
@Override public int compareTo(Entity entity) { if (this.getPriority() > entity.getPriority()) { return 1; } else if (this.getPriority() < entity.getPriority()) { return -1; } else { return this.getStr().compareTo(entity.getStr()); } } }
|