Java案例使用集合方法實(shí)現(xiàn)統(tǒng)計(jì)任意字符串中字符出現(xiàn)的次數(shù)
需求:鍵盤錄入一個(gè)字符串,統(tǒng)計(jì)其中各個(gè)字符出現(xiàn)的順序
分析:
- 1.使用
Scanner
類獲取一個(gè)字符串 - 2.創(chuàng)建
HashMap
集合,如果追求統(tǒng)計(jì)字符的美觀性,可以使用TreeMap - 3.遍歷字符串得到每一個(gè)字符并將其作為TreeMap的鍵
- 4.通過鍵去集合中找相對(duì)應(yīng)的值,看返回值是什么?
返回null:說明該字符在集合中不存在,就將該字符為鍵,次數(shù)1為值進(jìn)行存儲(chǔ)
返回的不是null:說明該字符在集合中存在,就再次將該字符作為鍵,次數(shù)+1為值進(jìn)行存儲(chǔ)
- 5.遍歷集合
public class TreeMapDemo { ? public static void main(String[] args) { ? ? ? //創(chuàng)建TreeMap集合對(duì)象 ? ? ? TreeMap<Character,Integer>tm=new TreeMap<Character,Integer>(); ? ? ? //創(chuàng)建Scanner對(duì)象 ? ? ? ? Scanner sc=new Scanner(System.in); ? ? ? System.out.println("請(qǐng)輸入一個(gè)字符串"); ? ? ? String s=sc.nextLine(); ? ? ? //遍歷字符串 ? ? ? for (int i=0;i<s.length();i++){ ? ? ? ? ? //獲取每一個(gè)字符 ? ? ? ? ? char key =s.charAt(i); ? ? ? ? ? //拿到的每一個(gè)字符到集合中找相對(duì)應(yīng)的值 ? ? ? ? ? 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); ? } } ?
補(bǔ)充:
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("請(qǐng)輸入一串字符"); //創(chuàng)建字符串對(duì)象,存儲(chǔ)鍵盤輸入的值 String line = scanner.nextLine(); //創(chuàng)建HashMap集合,鍵是character,值是Inter HashMap<Character, Integer> hm = new HashMap<Character, Integer>(); //循環(huán)遍歷字符串,得到每個(gè)字符 for (int i = 0; i < line.length(); i++) { //通過charAt方法,將字符串的索引值,作為鍵添加到HashMap集合中 char key = line.charAt(i); //使用HashMap集合的get方法,對(duì)集合中的鍵(字符)進(jìn)行判斷 //創(chuàng)建Integer對(duì)象存儲(chǔ)值 Integer value = hm.get(key); //返回值為空,將字符作為鍵,1作為存儲(chǔ)值 if (value == null) { hm.put(key, 1); } else { //返回值不為空,說明此字符在集合中出現(xiàn)過,將字符作為鍵,值加一 // 重新存儲(chǔ)鍵(字符)和對(duì)應(yīng)的值 value++; hm.put(key, value); } } //創(chuàng)建StringBuilder字符串序列 StringBuilder sb = new StringBuilder(); //創(chuàng)建set集合對(duì)象,通過keyset方法獲取鍵 Set<Character> keyset = hm.keySet(); //增強(qiáng)for循環(huán)遍歷,獲取鍵所對(duì)應(yīng)的值 for (Character key : keyset) { //使用get方法獲取到鍵所對(duì)應(yīng)的值 Integer value = hm.get(key); //對(duì)序列進(jìn)行拼接,使用append方法 sb.append(key).append("(").append(value).append(")"); } // 通過tostring方法返回StringBuilder此順序中的數(shù)據(jù)的字符串,創(chuàng)建string對(duì)象接受此字符串 String result = sb.toString(); //打印結(jié)果 System.out.println(result); } }
到此這篇關(guān)于Java案例使用集合方法實(shí)現(xiàn)統(tǒng)計(jì)任意字符串中字符出現(xiàn)的次數(shù)的文章就介紹到這了,更多相關(guān)Java集合統(tǒng)字符出現(xiàn)次數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- JAVA統(tǒng)計(jì)字符串中某個(gè)字符出現(xiàn)次數(shù)的方法實(shí)現(xiàn)
- Java實(shí)現(xiàn)統(tǒng)計(jì)字符串出現(xiàn)的次數(shù)
- Java統(tǒng)計(jì)一個(gè)字符串在另外一個(gè)字符串出現(xiàn)次數(shù)的方法
- Java統(tǒng)計(jì)英文句子中出現(xiàn)次數(shù)最多的單詞并計(jì)算出現(xiàn)次數(shù)的方法
- Java統(tǒng)計(jì)字符串中字符出現(xiàn)次數(shù)的方法示例
- Java編程實(shí)現(xiàn)統(tǒng)計(jì)數(shù)組中各元素出現(xiàn)次數(shù)的方法
- java統(tǒng)計(jì)字符串中重復(fù)字符出現(xiàn)次數(shù)的方法
- Java中計(jì)算集合中元素的出現(xiàn)次數(shù)統(tǒng)計(jì)
相關(guān)文章
Java實(shí)現(xiàn)替換集合中的元素的方法詳解
這篇文章主要為大家詳細(xì)介紹了Java中實(shí)現(xiàn)替換集合中的元素的常見方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02Java DefaultListableBeanFactory接口超詳細(xì)介紹
這篇文章主要介紹了Java DefaultListableBeanFactory接口,DefaultListableBeanFactory是整個(gè)bean加載的核心部分,是Spring注冊(cè)機(jī)加載bean的默認(rèn)實(shí)現(xiàn)2022-11-11后端如何接收格式為x-www-form-urlencoded的數(shù)據(jù)
x-www-form-urlencoded格式是一種常見的HTTP請(qǐng)求數(shù)據(jù)格式,它將請(qǐng)求參數(shù)編碼為鍵值對(duì)的形式,以便于傳輸和解析,下面這篇文章主要給大家介紹了關(guān)于后端如何接收格式為x-www-form-urlencoded的數(shù)據(jù),需要的朋友可以參考下2023-05-05Spring Boot和Kotlin的無(wú)縫整合與完美交融
這篇文章主要給大家介紹了關(guān)于Spring Boot和Kotlin的無(wú)縫整合與完美交融的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06Struts2攔截器Interceptor的原理與配置實(shí)例詳解
攔截器是一種AOP(面向切面編程)思想的編程方式.它提供一種機(jī)制是開發(fā)者能夠把相對(duì)獨(dú)立的代碼抽離出來,配置到Action前后執(zhí)行。下面這篇文章主要給大家介紹了關(guān)于Struts2攔截器Interceptor的原理與配置的相關(guān)資料,需要的朋友可以參考下。2017-11-11Java String.replace()方法"無(wú)效"的原因及解決方式
這篇文章主要介紹了Java String.replace()方法"無(wú)效"的原因及解決方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-08-08