>Java >java지도 시간 >Java 스트림에서 모든 최대값을 검색하여 동점을 효과적으로 처리하려면 어떻게 해야 합니까?

Java 스트림에서 모든 최대값을 검색하여 동점을 효과적으로 처리하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-14 14:45:16501검색

How Can I Retrieve All Maximum Values from a Java Stream, Handling Ties Effectively?

모든 최대값을 반환하는 Java Stream의 한계 극복

Stream의 max 함수는 스트림 내 최대값을 편리하게 식별합니다. 그러나 "선착순" 원칙에 따라 작동하므로 동률이 있는 경우 잠재적으로 다른 최대값을 제외할 수 있습니다. 이 제한 사항을 해결하고 모든 최대값을 검색하려면 대체 접근 방식이 필요합니다.

2단계 솔루션

입력 수집의 경우 2단계 접근 방식을 사용할 수 있습니다.

  1. 정수 길이의 max를 사용하여 최대값을 결정합니다.
  2. 컬렉션을 필터링하여 최대값을 가진 모든 문자열을 얻습니다. 길이입니다.

이 솔루션은 여러 최대값을 수용하지만 전체 입력을 두 번 반복하는 비용이 발생합니다.

단일 패스 수집기

입력이 스트림의 경우 단일 패스 수집기를 활용할 수 있습니다.

static <T> Collector<T, ?, List<T>> maxList(Comparator<? super T> comp) {
    return Collector.of(
        ArrayList::new,
        (list, t) -> {
            if (list.isEmpty() || comp.compare(t, list.get(0)) == 0) {
                list.add(t);
            } else if (comp.compare(t, list.get(0)) > 0) {
                list.clear();
                list.add(t);
            }
        },
        (list1, list2) -> {
            ...
            // Compare and merge lists based on maximum values
        }
    );
}

이 수집기는 동등성, 필요에 따라 요소를 추가하거나 제거합니다. 목록을 병합할 때 각 요소의 최대값을 고려하여 동일할 때 결합합니다.

이 컬렉터를 스트림과 결합하면 단일 패스에서 모든 최대값을 얻을 수 있습니다.

결론

Java 스트림의 max에는 한계가 있지만 대체 솔루션을 활용하여 이를 극복할 수 있습니다. 2패스 솔루션은 수집에 효율적인 반면, 단일 패스 수집기는 스트림에 유용하여 모든 최대값을 검색할 수 있습니다.

위 내용은 Java 스트림에서 모든 최대값을 검색하여 동점을 효과적으로 처리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.