1. 程式人生 > >將字符串中的字符按字符出現個數從大到小進行排序

將字符串中的字符按字符出現個數從大到小進行排序

DC println 遍歷 contains pan asdfasd [] 基本 pre

最近同事出去面試,有個關於將字符串數組中的字符串按出現次數排序按從大到小,要求5分鐘之內寫出來。很尷尬,沒有寫出來。我也來一次回顧吧

對於這種:

1 String stri = "agasdfasdfdccvvasdfg";

或者這種

1 String str = "a,b,c,a,v,d,f,s,s,f,f,sd";

其實都是一樣的。

第一種實現:

思路:1.將其轉化為數組,2.定義一個map,key為字符/字符串的值,value為出現的次數

   3.將map的value集合進行排序,這個排序是從大到小的排序

   4.遍歷排序後的value集合,如果原map中包含這個value,將重新將key和value寫入到linkedHashMap中去

代碼實現:

 1 public class TestSortDemo1 {
 2     public static void main(String[] args) {
 3         String str = "agadfsffdfvasdf";
 4         final char[] chars = str.toCharArray();
 5         Map<Character,Integer> map = new HashMap<>();
 6         for (char aChar : chars) {
 7             if
(map.containsKey(aChar)){ 8 map.put(aChar,map.get(aChar)+1); 9 }else { 10 map.put(aChar,1); 11 } 12 } 13 System.out.println(map); 14 List<Integer> list = new ArrayList<>(); 15 for (Integer integer : map.values()) {
16 list.add(integer); 17 } 18 //將values進行排序 19 Collections.sort(list); //正序 20 //Collections.sort(list,Comparator.reverseOrder()); //逆序 21 System.out.println(list); 22 LinkedHashMap<Character,Integer> linkedHashMap = new LinkedHashMap<>();//不會改變插入的順序 23 for (Integer value : list) { 24 for (Character character : map.keySet()) { 25 if(map.get(character)==value){ 26 linkedHashMap.put(character,value); 27 } 28 } 29 } 30 System.out.println(linkedHashMap); 31 System.out.println(linkedHashMap.keySet()); 32 } 33 }

運行的結果:

技術分享圖片

切換到正序運行結果:

技術分享圖片

另一種實現方式:在第三步以後略有不同,但是思想基本是相同的,3.將map轉為entryset,封裝進list裏面4,調用collections.sort方法,重寫比較方法

具體代碼實現:

 1 public static void main(String[] args) {
 2         String str = "agadfsffdfvasdf";
 3         final char[] chars = str.toCharArray();
 4         Map<Character, Integer> map = new HashMap<>();
 5         for (char aChar : chars) {
 6             if (map.containsKey(aChar)) {
 7                 map.put(aChar, map.get(aChar) + 1);
 8             } else {
 9                 map.put(aChar, 1);
10             }
11         }
12         System.out.println(map);
13         List<Map.Entry<Character,Integer>> list = new ArrayList<>();
14         list.addAll(map.entrySet());
15         Collections.sort(list, new Comparator<Map.Entry<Character, Integer>>() {
16             @Override
17             public int compare(Map.Entry<Character, Integer> o1, Map.Entry<Character, Integer> o2) {
18                 return o2.getValue() - o1.getValue();//從大到小
           //return o1.getValue() - o2.getValue();//從小到大
19 } 20 }); 21 System.out.println("從大到小的順序:"); 22 for (Map.Entry<Character, Integer> characterIntegerEntry : list) { 23 System.out.print(characterIntegerEntry.getKey()+","); 24 } 25 }

運性結果:

技術分享圖片

總結:

  兩種實現的方式核心思想都是一樣的,主要考察對集合的掌握。

後話:很久沒看,猛一接觸還是挺懵逼的。記錄下來也是對知識的一次回顧吧。

將字符串中的字符按字符出現個數從大到小進行排序