首頁 > 軟體

Java案例使用集合方法實現統計任意字串中字元出現的次數

2022-04-01 19:02:17

需求:鍵盤錄入一個字串,統計其中各個字元出現的順序

分析:

  • 1.使用Scanner類獲取一個字串
  • 2.建立HashMap集合,如果追求統計字元的美觀性,可以使用TreeMap
  • 3.遍歷字串得到每一個字元並將其作為TreeMap的鍵
  • 4.通過鍵去集合中找相對應的值,看返回值是什麼?

返回null:說明該字元在集合中不存在,就將該字元為鍵,次數1為值進行儲存

返回的不是null:說明該字元在集合中存在,就再次將該字元作為鍵,次數+1為值進行儲存

  • 5.遍歷集合
public class TreeMapDemo {
    public static void main(String[] args) {
        //建立TreeMap集合物件
        TreeMap<Character,Integer>tm=new TreeMap<Character,Integer>();
        //建立Scanner物件
​
        Scanner sc=new Scanner(System.in);
        System.out.println("請輸入一個字串");
        String s=sc.nextLine();
        //遍歷字串
        for (int i=0;i<s.length();i++){
            //獲取每一個字元
            char key =s.charAt(i);
            //拿到的每一個字元到集合中找相對應的值
            Integer value=tm.get(key);
            //判斷返回值
            if (value==null){
                tm.put(key,1);
            }else {
                value++;
                tm.put(key,value);
            }
        }
        //遍歷集合並拼接
        StringBuilder sb=new StringBuilder();
       Set<Character> keySet=tm.keySet();
        for (char key :keySet){
            Integer value=tm.get(key);
            sb.append(key).append("(").append(value).append(")");
​
        }
        String result = sb.toString();
        System.out.println(result);
    }
}
​

補充:

import java.util.HashMap;
  import java.util.Scanner;
  import java.util.Set;
  
  public class MapTest {
      public static void main(String[] args) {
         Scanner scanner = new Scanner(System.in);
          //鍵盤錄入字串
          System.out.println("請輸入一串字元");
        //建立字串物件,儲存鍵盤輸入的值
        String line = scanner.nextLine();
         //建立HashMap集合,鍵是character,值是Inter
         HashMap<Character, Integer> hm = new HashMap<Character, Integer>();
        //迴圈遍歷字串,得到每個字元
         for (int i = 0; i < line.length(); i++) {
             //通過charAt方法,將字串的索引值,作為鍵新增到HashMap集合中
             char key = line.charAt(i);
             //使用HashMap集合的get方法,對集合中的鍵(字元)進行判斷
             //建立Integer物件儲存值
             Integer value = hm.get(key);
            //返回值為空,將字元作為鍵,1作為儲存值
            if (value == null) {
                hm.put(key, 1);
             } else {
                //返回值不為空,說明此字元在集合中出現過,將字元作為鍵,值加一
                // 重新儲存鍵(字元)和對應的值
                 value++;
                 hm.put(key, value);
             }
         }
        //建立StringBuilder字串序列
         StringBuilder sb = new StringBuilder();
         //建立set集合物件,通過keyset方法獲取鍵
        Set<Character> keyset = hm.keySet();
         //增強for迴圈遍歷,獲取鍵所對應的值
         for (Character key : keyset) {
             //使用get方法獲取到鍵所對應的值
             Integer value = hm.get(key);
             //對序列進行拼接,使用append方法
             sb.append(key).append("(").append(value).append(")");
         }
         // 通過tostring方法返回StringBuilder此順序中的資料的字串,建立string物件接受此字串
        String result = sb.toString();
       //列印結果
        System.out.println(result);
    }
 }

到此這篇關於Java案例使用集合方法實現統計任意字串中字元出現的次數的文章就介紹到這了,更多相關Java集合統字元出現次數內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com