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

