亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

使用 StreamTokenizer () 、 HashMap() 、 HashSet()

使用 StreamTokenizer () 、 HashMap() 、 HashSet()

夢里花落0921 2022-07-27 09:28:34
import java.io.*;import java.util.*;class A {    public static void main(String args[]) throws Exception {        Console con = System.console();        String str;        int i=0;          HashMap map = new HashMap();        HashSet set = new HashSet();         System.out.println("Enter File Name : ");        str = con.readLine();        File f = new File(str);        f.createNewFile();                FileInputStream fis = new FileInputStream(str);        StreamTokenizer st = new StreamTokenizer(fis);        while(st.nextToken()!=StreamTokenizer.TT_EOF) {         String s;             switch(st.ttype) {             case StreamTokenizer.TT_NUMBER:  s = st.nval+"";             break;              case StreamTokenizer.TT_WORD:    s = st.sval;               break;                default: s = ""+((char)st.ttype);            }            map.put(i+"",s);            set.add(s);            i++;        }         Iterator iter = set.iterator();        System.out.println("Frequency Of Words :");        while(iter.hasNext()) {          String word;          int count=0;          word=(String)iter.next();                      for(int j=0; j<i ; j++) {             String word2;              word2=(String)map.get(j+"");               if(word.equals(word2))                count++;            }            System.out.println(" WORD : "+ word+" = "+count);        }        System.out.println("Total Words In Files: "+i);    }}在此代碼中,首先我已經創建了一個包含以下數據的文本文件:@Hello Hii World#* c++ java salesforce這段代碼的輸出是:**詞頻:字:# = 1字:@ = 1字:c = 1字:銷售人員 = 1字:* = 1字:這= 1字:+ = 2字:java = 1字:世界 = 1單詞:你好 = 1文件總字數:11**我無法找到為什么這將 c++ 顯示為單獨的單詞。我想在輸出中將 c++ 組合為一個單詞
查看完整描述

1 回答

?
holdtom

TA貢獻1805條經驗 獲得超10個贊

你可以這樣做


    // Create the file at path specified in the String str

    // ...

    HashMap<String, Integer> map = new HashMap<>();

    InputStream fis = new FileInputStream(str);

    Reader bufferedReader = new BufferedReader(new InputStreamReader(fis));


    StreamTokenizer st = new StreamTokenizer(bufferedReader);

    st.wordChars('+', '+');

    while(st.nextToken() != StreamTokenizer.TT_EOF) {

        String s;


        switch(st.ttype) {

            case StreamTokenizer.TT_NUMBER:

                s = String.valueOf(st.nval);

                break;

            case StreamTokenizer.TT_WORD:

                s = st.sval;

                break;

            default:

                s = String.valueOf((char)st.ttype);

        }

        Integer val = map.get(s);

        if(val == null)

            val = 1;

        else

            val++;

        map.put(s, val);

    }


    Set<String> keySet = map.keySet();

    Iterator<String> iter = keySet.iterator();

    System.out.println("Frequency Of Words :");

    int sum = 0;

    while(iter.hasNext()) {

        String word = iter.next();

        int count = map.get(word);

        sum += count;

        System.out.println(" WORD : " + word + " = " + count);

    }

    System.out.println("Total Words In Files: " + sum);

請注意,我使用泛型而不是原始版本的 HashMap 和迭代器更新了您的代碼。此外,您用于 StreamTokenizer 的構造函數已被棄用。使用 map 和 set 是沒有用的,因為您可以使用 .keySet() 方法迭代 map 的鍵集。該映射現在從 String(單詞)變為 Integer(單詞數)。


無論如何,關于您所做的示例,我認為簡單的拆分方法會更合適。


有關 StreamTokenizer 的 wordChars 方法的更多信息,您可以查看#wordChars(int, int)


查看完整回答
反對 回復 2022-07-27
  • 1 回答
  • 0 關注
  • 108 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號