使用Java8优雅的获取重复字符与次数

本文介绍在Java8中,我们应该如何进行字符及字符串的去重,以及计算去重次数。

获取重复的字符以及重复的次数

java 复制代码
package com.javatute.stream;

import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;

public class DuplicateCharacter {
    public static void main(String[] args) {
        String input = "rakeshranjankumar";

        Map<Character, Long> charCountMap = input.chars()
                .mapToObj(c -> (char) c)
                .collect(Collectors.groupingBy( 
                        Function.identity(), Collectors.counting()
                ));

        charCountMap.forEach((character, count) -> {
            if (count > 1) {
                System.out.println("Character: " + character + ", Count: " + count);
            }
        });
    }
}

输出如下:

Character: a, Count: 4 Character: r, Count: 3 Character: k, Count: 2 Character: n, Count: 2

  • 我们使用该 chars() 方法将输入字符串转换为字符流。
  • 然后,我们将每个字符映射到一个类型的 Character 对象。
  • 使用收集器 Collectors.groupingBy 按字符的身份(即字符本身)对字符进行分组,并使用 Collectors.counting() 计算它们的出现次数。
  • 结果是 Map<Character, Long> 其中键是字符串中的唯一字符,值是每个字符的计数。
  • 遍历Map并打印计数大于 1 的字符,这表示它们是重复的

使用 Java 8 计算重复字符串的程序

要使用 Java 8 查找重复的字符串并计算它们在字符串集合中的出现次数,您可以将 Stream API 与 groupingBy 收集器一起使用

java 复制代码
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;

public class Main {
    public static void main(String[] args) {
        List<String> strings = Arrays.asList("apple", "banana", "apple", "cherry", "banana", "date", "apple");

        Map<String, Long> stringCountMap = strings.stream()
            .collect(Collectors.groupingBy(
                Function.identity(), Collectors.counting()
            ));

        stringCountMap.forEach((str, count) -> {
            if (count > 1) {
                System.out.println("String: " + str + ", Count: " + count);
            }
        });
    }
}

输出如下:

String: banana, Count: 2 String: apple, Count: 3

  • 首先我们有一个字符串列表,称为 strings
  • 将列表转换为字符串流。
  • 使用收集器 Collectors.groupingBy 按字符串的身份(即字符串本身)对字符串进行分组,并使用 Collectors.counting()
  • 结果是,键是列表中的唯一字符串, Map<String, Long> 值是每个字符串的计数
  • 遍历Map计数大于 1 的字符串,打印重复的字符串。
    以上就是利用Java8进行字符及字符串的查重了,是不是非常优雅呢?
相关推荐
Daniel 大东5 分钟前
idea 解决缓存损坏问题
java·缓存·intellij-idea
wind瑞11 分钟前
IntelliJ IDEA插件开发-代码补全插件入门开发
java·ide·intellij-idea
HappyAcmen11 分钟前
IDEA部署AI代写插件
java·人工智能·intellij-idea
马剑威(威哥爱编程)17 分钟前
读写锁分离设计模式详解
java·设计模式·java-ee
鸽鸽程序猿17 分钟前
【算法】【优选算法】前缀和(上)
java·算法·前缀和
修道-032318 分钟前
【JAVA】二、设计模式之策略模式
java·设计模式·策略模式
九圣残炎23 分钟前
【从零开始的LeetCode-算法】2559. 统计范围内的元音字符串数
java·算法·leetcode
当归102436 分钟前
若依项目-结构解读
java
hlsd#1 小时前
关于 SpringBoot 时间处理的总结
java·spring boot·后端
iiiiiankor1 小时前
C/C++内存管理 | new的机制 | 重载自己的operator new
java·c语言·c++