java8统计字符串字母个数的⼏种⽅法总结(推荐)1.统计字符串字母个数(并且保持字母顺序)
⽐如: aabbbbbbbba喔喔bcab cdabc deaaa
⽬前我做知道的有5种⽅式噢,如果你还有更好的,欢迎赐教
//⽅式1
public static void letterCount1(String s) {
placeAll(" +", "");
//1,转换成字符数组
char c[]=s.toCharArray();
Map<Character, Integer> tree=new TreeMap<Character, Integer>();
for (int i = 0; i < c.length; i++) {
//第⼀次:a,1
/
/第⼆次:a,2
//2,获取键所对应的值
Integer (c[i]);
// 反编译:Integer value = ((Character.valueOf(c[i]));
//3,存储判断
tree.put(c[i], value==null? 1:value+1);
}
//如果要求结果格式:a(5)b(4)c(3)d(2)e(1)
StringBuilder sbu=new StringBuilder();
for(Character key:tree.keySet()){
Integer (key);
sbu.append(key).append("(").append(count).append(")");
}
//将sbu转换为字符串
System.out.String());
}
//⽅式2 使⽤流
//这个在测试特殊字符,⽐如\ \n时,他的顺序会不对,这个是Map造成的
//解决办法使⽤TreeMap
public static void letterCount2(String s) {
placeAll(" +", "");
TreeMap<String, Long> result = Arrays.stream(s.split(""))
.
sorted()
// .upingBy(Function.identity(),unting()));
.upingBy(Function.identity(),TreeMap::unting()));
System.out.println(result);
}
//⽅式3 使⽤Collections.frequencyreplaceall()
//其实就是字符串变成集合存每个字串,把每个字串循环跟集合⽐较
public static void letterCount3(String s) {
placeAll(" +", "");
List<String> list=Arrays.asList(s.split(""));
Map<String,Integer> map=new TreeMap<String, Integer>();
for (String str : list) {
map.put(str, Collections.frequency(list, str));
}
System.out.println(map);
}
//⽅式4
public static void letterCount4(String s) {
placeAll(" +", "");
String[] strs = s.split("");
Map<String,Integer> map=new TreeMap<String, Integer>();
for (String str : strs) {
map.put(str, stringCount(s, str));
}
System.out.println(map);
}
//⽅式5
public static void letterCount5(String s) {
placeAll(" +", "");
String[] strs = s.split("");
Map<String,Integer> map=new TreeMap<String, Integer>();
for (String str : strs) {
map.put(str, stringCount2(s, str));
}
System.out.println(map);
}
//巧⽤split
public static int stringCount(String maxstr, String substr) {
// 注意
// 1.⽐如qqqq,没有到,则直接返回这个字符串
// 2.⽐如qqqjava,末尾没有其他字符,这时也不会分割,所以可以添加⼀个空格
// 3.java11开头没有字符,没有关系,⾃动空填充
// 4.对于特殊字符,要注意使⽤转义符
int count = (maxstr + " ").split(substr).length - 1;
/
/ System.out.println("\"" + minstr + "\"" + "字符串出现次数:" + count);
return count;
}
//如果要不区分⼤⼩写,则compile(minstr,CASE_INSENSITIVE)
public static int stringCount2(String maxstr, String substr) {
int count = 0;
Matcher m = Patternpile(substr).matcher(maxstr);
while (m.find()) {
count++;
}
return count;
}
2.统计字符串的单词个数(只限英⽂)
这个其实跟上⾯⼀样的,下⾯只写⼀个简洁的⽅法
public static void wordStringCount(String s) {
//这⾥开始是字符串,分割后变成字符串流
Map<String, Long> result = Arrays.stream(s.split("\\s+"))
.map(word -> placeAll("[^a-zA-Z]", ""))
.upingBy(Function.identity(),unting())); System.out.println(result);
}
3.统计⽂本单词个数(只限英⽂)
//统计⼀个⽂本中单词的个数
public static void wordFileCount(String path) throws IOException{
//这⾥⼀开始字符串流
//先分割
//在变成字符流
//在筛选
Map<String, Long> result = Files.(path),Charset.defaultCharset())
.parallel()
//字符串流--分割--字符串流
.flatMap(str->Arrays.stream(str.split(" +")))
.map(word -> placeAll("[^a-zA-Z]", ""))
//去掉空
.
filter(word->word.length()>0)
.upingBy(Function.identity(),unting()));
System.out.println(result);
}
4.其他不相⼲的
我们知道,可变参数列表,可以不传参数的
对于
public void testName() {
System.out.println("a");
}
public void testName(String ... s) {
/
/不传参数,s会默认初始化⼀个对象
System.out.println("b");
}
此时调⽤testName() 打印什么呢?,会打印a,会⾃动匹配参数真正为空的⽅法
以上这篇java8 统计字符串字母个数的⼏种⽅法总结(推荐)就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论