本文实例讲述了java统计英文句子中出现次数最多的单词并计算出现次数的方法。分享给大家供大家参考,具体如下:
import java.util.*; /** * 统计出现次数最多的单词和它出现的次数 * * @author zhr */ public class countword { public static string[] strtostrarray(string str) { /* * 将非字母字符全部替换为空格字符" " 得到一个全小写的纯字母字符串包含有空格字符 */ str = str.tolowercase();// 将字符串中的英文部分的字符全部变为小写 string regex = "[\\w]+";// 非字母的正则表达式 --\w:表示任意一个非单词字符 str = str.replaceall(regex, " "); string[] strs = str.split(" "); // 以空格作为分隔符获得字符串数组 return strs; } public static void countword(string[] strs) { /* * 建立字符串(string)出现次数(integer)的映射 */ hashmap<string, integer> strhash = new hashmap<string, integer>(); integer in = null;// 用于存放put操作的返回值 for (string s : strs) {// 遍历数组 strs in = strhash.put(s, 1); if (in != null) {// 判断如果返回的不是null,则+1再放进去就是出现的次数 strhash.put(s, in + 1); } } set<java.util.map.entry<string, integer>> entryset = strhash.entryset(); string maxstr = null;// 用于存放出现最多的单词 int maxvalue = 0;// 用于存放出现最多的次数 for (java.util.map.entry<string, integer> e : entryset) { string key = e.getkey(); integer value = e.getvalue(); if (value > maxvalue) { maxvalue = value;// 这里有自动拆装箱 maxstr = key; } } system.out.println("出现最多的单词是:" + maxstr + "出现了" + maxvalue + "次"); } @suppresswarnings("resource") public static void main(string[] args) { scanner scan = new scanner(system.in); system.out.println("请输入一行英文句子:"); string str = scan.nextline(); system.out.println("输入的英文句子为:" + str); string[] strs = strtostrarray(str); countword(strs); } }
运行结果:
ps:这里再为大家推荐2款非常方便的统计工具供大家参考使用:
在线字数统计工具:
在线字符统计与编辑工具:
更多关于java算法相关内容感兴趣的读者可查看本站专题:《java数据结构与算法教程》、《java操作dom节点技巧总结》、《java文件与目录操作技巧汇总》和《java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
如对本文有疑问, 点击进行留言回复!!
[JVM学习之路]一、初识JVM,了解其结构、模型及生命周期
【JAVA并发编程】LinkedBlockingQueue原理
网友评论