java-統計一段句子中各單詞出現的次數
- 問題:統計一段句子中各單詞出現的次數。
- 思路:
- 一、使用split方法將文章進行分割,咱們這裏以空格、逗號和句點爲分隔符,而後存到一個字符串數組中。
- 二、建立一個hashMap集合,key是字符串類型,保存單詞;value是數字類型,保存該單詞出現的次數。
- 三、遍歷思路1中的字符串數組,若是key(單詞)沒有出現過,map中增長一個元素,key爲該單詞,定義value爲1;若是key(單詞)出現過,那麼value的值加1。
- 4.遍歷輸入key及其對應的value值。
- 具體代碼以下:
- StrList類,實現統計單詞出現次數的方法。
- package wordCounts;
- import java.util.HashMap;
- import java.util.Map.Entry;
- public class StrList {
- public String StatList(String s) {
- StringBuffer sb = new StringBuffer();
- HashMap<String, Integer> has = new HashMap<String,Integer>();//打開哈希表,字符類型儲存key(單詞),整型儲存value(單詞出現的次數)
- String[] sList = s.split(" |,|\\.");//使用split方法將字符串s按空格、逗號和句點分割開,並存在字符數組sList中
- for(int i=0; i<sList.length; i++){//遍歷sList數組
- if(!has.containsKey(sList[i])){//若是沒有這個單詞,就將單詞存入key裏,value值爲1;containsKey方法 判斷集合中是否包含指定的key
- has.put(sList[i], 1);
- }else{//若是已經存在,就將value值加1;用get方法獲取key對應的value值
- has.put(sList[i], has.get(sList[i])+1);
- }
- }
- //使用加強for循環遍歷,經過Entry集合訪問,能夠訪問key及其對應的Value值
- for(Entry<String, Integer> entry:has.entrySet()){
- System.out.println(entry.getKey()+":"+entry.getValue());
- }
- return sb.toString();
- }
- }
- main方法(建立另外一個類):
- 方式一:已經指定好了句子
- package wordCounts;
- import java.util.Scanner;
- public class WordCounts{
- public static void main(String[] args) {
- String sentence = "The most distant way in the world,"
- + "is not the way from birth to the end. "
- + "It is when I stand in front of you,"
- + "but you don't understand I love you.";
- System.out.println(StatList(sentence));
- }
- }
- 方式二:從鍵盤輸入
- package wordCounts;
- import java.util.Scanner;
- public class WordCounts{
- public static void main(String[] args) {
- @SuppressWarnings("resource")
- Scanner scanner = new Scanner(System.in);
- String ab = scanner.nextLine();
- StrList sl = new StrList();
- System.out.println(sl.StatList(ab));
- }
- }
- ————————————————
歡迎關注本站公眾號,獲取更多信息