Java实现统计英语句子中每个单词出现的次数(不区分单词大小写)

给出一个英语句子,统计每个单词(不区分大小写)出现的次数,Java代码如下:

public class CountWords {
    public static void main(String[] args) {
        countWords(" Hi, this is first line. This is second line.");
    }

    public static void countWords(String string) {
        // 正则表达式,获得句子中的单词
        String[] str = string.trim().split("[,。?,.? ]");
        // LinkedHashMap基于链表,可以保证有序
        Map<String, Integer> map = new LinkedHashMap<>();
        for (int i = 0; i < str.length; i++) {
            if (!("".equals(str[i]))) {
                // 遍历key的集合,判断key(不区分大小写)是否已存在
                Iterator<String> it = map.keySet().iterator();
                // 用来标记key在map集合总是否存在
                boolean exist = false;
                // 遍历key的set集合
                while (it.hasNext()) {
                    String key = it.next();
                    // 如果key已存在,值加1
                    if (key.equalsIgnoreCase(str[i])) {
                        exist = true;
                        map.put(key, map.get(key) + 1);
                    }
                }
                // map中不存在就添加
                if (exist == false) {
                    map.put(str[i], 1);
                }
            }
        }
        // 遍历map集合
        for (Map.Entry<String, Integer> entry : map.entrySet()) {
            System.out.println(entry.getKey() + ":" + entry.getValue());
        }
    }
}

输出结果:

Hi:1
this:2
is:2
first:1
line:2
second:1

猜你喜欢

转载自blog.csdn.net/new1111111/article/details/81162885