搜索HashMap Java的键和增量值

时间:2018-10-27 23:47:52

标签: java hashmap

在我的方法中,我的目标是将字符串中的单词存储到HashMap中。它们的键将是一个单词,结果将是单词出现的次数。

到目前为止,我已经尝试了搜索部分,但是对于增加的部分,我将其保留为仅打印是,因为我也没有弄清楚该怎么做。

到目前为止,我只是希望程序在重复的次数上打印yes,但是,我的if语句却出现异常。

public void countWord(){

    String tokens[] = userInput.trim().replaceAll("\\s+", " ").split(" ");

    for(int i = 0; i < tokens.length; ++i) {
        if(bow.containsKey(tokens[i])) {
            System.out.printf("yes\n");
        }
        else {
            bow.put(tokens[i], 1);
        }
    }
}

我假设bow.containsKey(tokens[i]))的语法不正确,我想知道如何替换它。

1 个答案:

答案 0 :(得分:1)

您需要在地图上检查当前令牌的计数器,如果不存在,请创建一个值为0的计数器,然后递增计数器并将其放回地图中

public void countWord(){

    String tokens[] = userInput.trim().replaceAll("\\s+", " ").split(" ");

    for(int i = 0; i < tokens.length; ++i) {
        Integer counter = bow.get(tokens[i]);
        if(counter == null) {
            counter = 0;
        }
        bow.put(tokens[i], ++counter);
    }
}

如果您想改善此语法bow.containsKey(tokens[i])) 您可以将令牌[i]存储在变量中

public void countWord(){

    String tokens[] = userInput.trim().replaceAll("\\s+", " ").split(" ");

    for(int i = 0; i < tokens.length; ++i) {
        String token = tokens[i];
        Integer counter = bow.get(token);
        if(counter == null) {
            counter = 0;
        }
        bow.put(token, ++counter);
    }
}