Как вы используете PartitioningBy в потоках, чтобы найти значения выше и ниже среднего? - PullRequest
2 голосов
/ 02 августа 2020

Я здесь новичок, пытаюсь разработать синтаксис потока для одного из моих проектов. Мой проект - это счетчик значений слова Scrabble, где у меня есть метод, использующий HashMap для хранения букв и их значений, а у меня есть массив String, в котором хранятся слова, которые необходимо обработать. Используя поток, я смог получить тройку лучших и среднее значение слов. В настоящее время у меня возникают проблемы с поиском:

  • этих слов выше среднего
  • этих слов ниже среднего

Как мне разделить значения на указанные выше и ниже среднего с использованием метода partitioningBy? Имея в виду, что это нужно делать через потоки.

Вот мой код:

import java.util.Arrays;
import java.util.HashMap;
import java.util.IntSummaryStatistics;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;
import java.util.stream.IntStream;
import java.util.stream.Stream;

public class scrabble {

    public static int scrapleVal(String word)
    {
    Map<Character, Integer> letterValues = new HashMap<>();

    letterValues.put('a', 1);
    letterValues.put('b', 3);
    letterValues.put('c', 3);
    letterValues.put('d', 2);
    letterValues.put('e', 1);
    letterValues.put('f', 4);
    letterValues.put('g', 2);
    letterValues.put('h', 4);
    letterValues.put('i', 1);
    letterValues.put('j', 8);
    letterValues.put('k', 5);
    letterValues.put('l', 1);
    letterValues.put('m', 3);
    letterValues.put('n', 1);
    letterValues.put('o', 1);
    letterValues.put('p', 3);
    letterValues.put('q', 10);
    letterValues.put('r', 1);
    letterValues.put('s', 1);
    letterValues.put('t', 1);
    letterValues.put('u', 1);
    letterValues.put('v', 8);
    letterValues.put('w', 4);
    letterValues.put('x', 8);
    letterValues.put('y', 4);
    letterValues.put('z', 10);

    return word.toLowerCase().chars().map(e->letterValues.get((char)e)).sum();
    }

    public static void main(String[] args) {



    String [] words = {"Java", "program", "list", "string", "unix",
    "hours", "syntax", "error"};
    
    //top three words
    System.out.println("Top three words are: ");
    Stream.of(words).sorted((e1,e2)->scrapleVal(e2)-scrapleVal(e1)).limit(3).forEach
    (e->System.out.println(e+" : "+scrapleVal(e)));
    //average word value
    System.out.println("\nAverage value fo words is: ");
    double averageScrapleValue = Stream.of(words)
    .mapToInt(scrabble::scrapleVal).average().orElse(0.0);
    System.out.println(averageScrapleValue);
    //above average words
    Stream.of(words).collect(Collectors
    .partitioningBy((scrabble::scrapleVal) > averageScrapleValue)).forEach
    (e->System.out.println(e+" : "+scrapleVal(e)));
    //below average words
    Stream.of(words).collect(Collectors
    .partitioningBy((scrabble::scrapleVal) < averageScrapleValue)).forEach
    (e->System.out.println(e+" : "+scrapleVal(e)));
    }
    }

1 Ответ

1 голос
/ 05 августа 2020

Вы получаете данные на карте после partitioningBy

Map<Boolean, List<String>> 
            map = Stream.of(words).collect(Collectors
                  .partitioningBy(w -> scrapleVal(w) < averageScrapleValue));

Здесь map.get(true) дает среднее значение ниже, а map.get(false) дает равное и выше среднего слова.

List<String> bellowAvg = map.get(true);
List<String> aboveAndEqualAvg = map.get(false);

Вывод:

[list, string, hours, error]
[Java, program, unix, syntax]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...