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)文章
Springcould多模塊搭建Eureka服務(wù)器端口過(guò)程詳解
這篇文章主要介紹了Springcould多模塊搭建Eureka服務(wù)器端口過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
java 數(shù)據(jù)的加密與解密普遍實(shí)例代碼
本篇文章介紹了一個(gè)關(guān)于密鑰查詢的jsp文件簡(jiǎn)單實(shí)例代碼,需要的朋友可以參考下2017-04-04
Java?DelayQueue實(shí)現(xiàn)任務(wù)延時(shí)示例講解
DelayQueue是一個(gè)無(wú)界的BlockingQueue的實(shí)現(xiàn)類,用于放置實(shí)現(xiàn)了Delayed接口的對(duì)象,其中的對(duì)象只能在其到期時(shí)才能從隊(duì)列中取走。本文就來(lái)利用DelayQueue實(shí)現(xiàn)延時(shí)任務(wù),感興趣的可以了解一下2022-09-09
使用Java將DOCX文檔解析為Markdown文檔的代碼實(shí)現(xiàn)
在現(xiàn)代文檔處理中,Markdown(MD)因其簡(jiǎn)潔的語(yǔ)法和良好的可讀性,逐漸成為開發(fā)者、技術(shù)寫作者和內(nèi)容創(chuàng)作者的首選格式,然而,許多文檔仍然以Microsoft Word的DOCX格式保存,本文將介紹如何使用Java和相關(guān)庫(kù)將DOCX文檔解析為Markdown文檔,需要的朋友可以參考下2025-04-04
IntelliJ IDEA多屏后窗口不顯示問(wèn)題解決方案
這篇文章主要介紹了IntelliJ IDEA多屏后窗口不顯示問(wèn)題解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
idea項(xiàng)目報(bào)錯(cuò)缺失maven依賴問(wèn)題及解決
這篇文章主要介紹了idea項(xiàng)目報(bào)錯(cuò)缺失maven依賴問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03

