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.通過(guò)鍵去集合中找相對(duì)應(yīng)的值,看返回值是什么?
返回null:說(shuō)明該字符在集合中不存在,就將該字符為鍵,次數(shù)1為值進(jìn)行存儲(chǔ)
返回的不是null:說(shuō)明該字符在集合中存在,就再次將該字符作為鍵,次數(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++) {
//通過(guò)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 {
//返回值不為空,說(shuō)明此字符在集合中出現(xiàn)過(guò),將字符作為鍵,值加一
// 重新存儲(chǔ)鍵(字符)和對(duì)應(yīng)的值
value++;
hm.put(key, value);
}
}
//創(chuàng)建StringBuilder字符串序列
StringBuilder sb = new StringBuilder();
//創(chuàng)建set集合對(duì)象,通過(guò)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(")");
}
// 通過(guò)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)替換集合中的元素的常見(jiàn)方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02
消息隊(duì)列-kafka消費(fèi)異常問(wèn)題
這篇文章主要給大家介紹了關(guān)于kafka的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07
Java 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格式是一種常見(jiàn)的HTTP請(qǐng)求數(shù)據(jù)格式,它將請(qǐng)求參數(shù)編碼為鍵值對(duì)的形式,以便于傳輸和解析,下面這篇文章主要給大家介紹了關(guān)于后端如何接收格式為x-www-form-urlencoded的數(shù)據(jù),需要的朋友可以參考下2023-05-05
Spring Boot和Kotlin的無(wú)縫整合與完美交融
這篇文章主要給大家介紹了關(guān)于Spring Boot和Kotlin的無(wú)縫整合與完美交融的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06
Struts2攔截器Interceptor的原理與配置實(shí)例詳解
攔截器是一種AOP(面向切面編程)思想的編程方式.它提供一種機(jī)制是開發(fā)者能夠把相對(duì)獨(dú)立的代碼抽離出來(lái),配置到Action前后執(zhí)行。下面這篇文章主要給大家介紹了關(guān)于Struts2攔截器Interceptor的原理與配置的相關(guān)資料,需要的朋友可以參考下。2017-11-11
Java String.replace()方法"無(wú)效"的原因及解決方式
這篇文章主要介紹了Java String.replace()方法"無(wú)效"的原因及解決方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08

