本文實例為大家分享了java統計文件中字符個數的具體代碼,供大家參考,具體內容如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
package com.zhu.io; import java.io.bufferedreader; import java.io.file; import java.io.filereader; import java.io.ioexception; import java.util.map; import java.util.set; import java.util.treemap; public class filecharacter{ map<character,integer>map= new treemap<character,integer>(); public filecharacter(string filename) throws ioexception{ bufferedreader br= new bufferedreader( new filereader( new file(filename))); int x; while ((x=br.read())> 0 ){ character key= new character(( char )x); if (map.containskey(key)){ int count=map.get(key); map.remove(key); map.put(key, ++count); } else { map.put(key, 1 ); } } } public int getcount( char c){ //獲取字符在文件中出現的個數 return map.get(c); } public set<character> getallchar(){ //獲取文件中字符的set集合 return map.keyset(); } public map<character,integer> getmap(){ //獲取字符與其出現個數組成的map集合 return map; } public void printinfo(){ //打印信息 set<map.entry<character, integer>>set=map.entryset(); for (map.entry<character, integer> entry:set){ system.out.println( "[ " +entry.getkey()+ " ]" + "\t" + "count:" +entry.getvalue()); } } public static void main(string[] args) throws ioexception { filecharacter fc= new filecharacter( "e:\\test.txt" ); fc.printinfo(); } } |
小編另為大家分享一段代碼:計算一個字符串中每個字符出現的次數
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
import java.util.hashmap; import java.util.map; import java.util.scanner; /** * 計算一個字符串中每個字符出現的次數 * * 思路: * 通過tochararray()拿到一個字符數組--> * 遍歷數組,將數組元素作為key,數值1作為value存入map容器--> * 如果key重復,通過getkey()拿到value,計算value+1后存入 */ public class test01 { public static void main(string[] args) { system.out.println( "請輸入字符串:" ); scanner sc= new scanner(system.in); while (sc.hasnextline()){ string str=sc.nextline(); map<character,integer> map =count(str); system.out.println(map); } } public static map<character,integer> count(string str){ map<character,integer> map= new hashmap<character,integer>(); char [] array_char=str.tochararray(); //把字符串轉成字符數組 for ( char arr_char: array_char){ //遍歷字符數組 if (map.containskey(arr_char)){ //查看字符是否在map的key中存在,如果存在 integer old=map.get(arr_char); //通過key獲取value的值 map.put(arr_char,old+ 1 ); //把字符放入map的key中,value設置為通過key獲取value的值+1 } else { //查看字符是否在map的key中存在,如果不存,把字符放入map的key中,value默認設置為1 map.put(arr_char, 1 ); } } return map; } } |
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/z956281507/article/details/72845563