黑马程序员技术交流社区

标题: Map中封装键值对对象的应用,根据键值排序 [打印本页]

作者: ☆今☆    时间: 2013-8-4 20:53
标题: Map中封装键值对对象的应用,根据键值排序
从键盘接收一行字符串, 统计每个字符出现的次数
按照字符出现的个数排序, 次数相同的按照字典顺序排序: a=1, d=1, c=2, b=3
  1. import java.util.Comparator;
  2. import java.util.Map;
  3. import java.util.Map.Entry;
  4. import java.util.Scanner;
  5. import java.util.Set;
  6. import java.util.TreeMap;
  7. import java.util.TreeSet;

  8. public class abc {
  9.         public static void main(String[] args) {
  10.                 Scanner sc = new Scanner(System.in);
  11.                 String str = sc.nextLine();
  12.                 sc.close();
  13.                 sortByCount(str);

  14.         }

  15.         private static void sortByCount(String str) {
  16.                 char[] arr = str.toCharArray();// 字符串装换为字符数组
  17.                 Map<Character, Integer> map = new TreeMap<>();
  18.                 putInMap(arr, map);//将键 和值装入集合
  19.                
  20.                 // 获取键值对,封装到Entry中,然后将Entry对象添加到TreeSet集合中,TreeSet中传一个比较器.
  21.                 Set<Entry<Character, Integer>> entrySet = map.entrySet();
  22.                 TreeSet<Entry<Character, Integer>> ts = new TreeSet<>(
  23.                                 new Comparator<Entry<Character, Integer>>() {
  24.                                         @Override
  25.                                         public int compare(Entry<Character, Integer> e1,
  26.                                                         Entry<Character, Integer> e2) {
  27.                                                 int num = e2.getValue() - e1.getValue();
  28.                                                 return num == 0 ? e1.getKey().compareTo(e2.getKey())
  29.                                                                 : num;
  30.                                         }
  31.                                 });
  32.                 ts.addAll(entrySet);
  33.                 System.out.println(ts);
  34.         }

  35.         private static void putInMap(char[] arr, Map<Character, Integer> map) {
  36.                 for (Character ch : arr) {
  37.                         map.put(ch, map.get(ch) == null ? 1 : map.get(ch) + 1);
  38.                 }
  39.         }
  40. }
复制代码

作者: 许庭洲    时间: 2013-8-7 07:05
值得学习ing!
作者: jrry    时间: 2013-8-9 13:45
不错,值得学习~




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2