Создайте карту String и отсортированный список, используя API потоков Java 8 - PullRequest
2 голосов
/ 27 июня 2019

У меня есть следующие классы:

class Data {
        String systemId;
        String fileName;
        int x;
        int y;

        Data(String systemId, String fileName, int x, int y) {
            this.systemId = systemId;
            this.fileName = fileName;
            this.x = x;
            this.y = y;
        }
        public String getSystemId() {
            return systemId;
        }

        public void setSystemId(String systemId) {
            this.systemId = systemId;
        }

        public String getFileName() {
            return fileName;
        }

        public void setFileName(String fileName) {
            this.fileName = fileName;
        }

        public int getX() {
            return x;
        }

        public void setX(int x) {
            this.x = x;
        }

        public int getY() {
            return y;
        }

        public void setY(int y) {
            this.y = y;
        }
    }


class Result {
        int x;
        int y;

        Result(int x, int y) {
            this.x = x;
            this.y = y;
        }

        public int getX() {
            return x;
        }

        public void setX(int x) {
            this.x = x;
        }

        public int getY() {
            return y;
        }

        public void setY(int y) {
            this.y = y;
        }
    }

List<Data> dataList = new ArrayList<>();
Data x1 = new Data("n1", "f1", 3, 4);
Data x2 = new Data("n1", "f1", 1, 2);
Data x3 = new Data("n1", "f1", 5, 6);
Data x4 = new Data("n1", "f2", 7, 8);
Data x5 = new Data("n2", "f1", 9, 10);
Data x6 = new Data("n2", "f2", 11, 12);
Data x7 = new Data("n3", "f1", 13, 14);
Data x8 = new Data("n4", "f1", 15, 16);
Data x9 = new Data("n1", "f1", 5, 10);
Data x10 = new Data("n1", "f1", 5, 2);

dataList.add(x1);dataList.add(x2);dataList.add(x3);dataList.add(x4);dataList.add(x5);dataList.add(x6);dataList.add(x7);dataList.add(x8);

Я хочу использовать потоки Java для создания Map<String, List<Result>> из заданного списка ввода. Кроме того, значения списка должны быть отсортированы в порядке возрастания в соответствии с полями (x и y)

Мне нужно, чтобы выходная карта была следующей:

{"n1:f1" : [(1, 2), (3, 4), (5, 2), (5,6), (5,10)]
 "n1:f2" : [(7, 8)]
 "n2:f1" : [(9, 10)]
 "n2:f2" : [(11, 12)]
 "n3:f1" : [(13, 14)]
 "n4:f1" : [(15, 16)]
}

Ключом для карты является комбинация systemid и имени файла, соединенных двоеточием. Значения списка должны быть сначала отсортированы по x, а затем по y.

Ответы [ 2 ]

4 голосов
/ 27 июня 2019

что-то вроде:

Map<String, List<Result>> collect = dataList.stream()
            .sorted(Comparator.comparing(Data::getX).thenComparing(Data::getY))
            .collect(Collectors.groupingBy(d ->  d.getSystemId() + ":" + d.getFileName(),
                    Collectors.mapping(d -> new Result(d.getX(), d.getY()), toList())));
0 голосов
/ 27 июня 2019
class Data {
        String systemId;
        String fileName;
        int x;
        int y;

        Data(String systemId, String fileName, int x, int y) {
            this.systemId = systemId;
            this.fileName = fileName;
            this.x = x;
            this.y = y;
        }
        public String getSystemId() {
            return systemId;
        }

        public void setSystemId(String systemId) {
            this.systemId = systemId;
        }

        public String getFileName() {
            return fileName;
        }

        public void setFileName(String fileName) {
            this.fileName = fileName;
        }

        public int getX() {
            return x;
        }

        public void setX(int x) {
            this.x = x;
        }

        public int getY() {
            return y;
        }

        public void setY(int y) {
            this.y = y;
        }
    }


class Result {
        int x;
        int y;

        Result(int x, int y) {
            this.x = x;
            this.y = y;
        }

        public int getX() {
            return x;
        }

        public void setX(int x) {
            this.x = x;
        }

        public int getY() {
            return y;
        }

        public void setY(int y) {
            this.y = y;
        }

        @Override
        public String toString() {

        return "("+getX() +","+ getY()+")";
        }
    }

public class MainClass {
    public static void main(String[] args) {

        List<Data> dataList = new ArrayList<Data>();
        Data x1 = new Data("n1", "f1", 3, 4);
        Data x2 = new Data("n1", "f1", 1, 2);
        Data x3 = new Data("n1", "f1", 5, 6);
        Data x4 = new Data("n1", "f2", 7, 8);
        Data x5 = new Data("n2", "f1", 9, 10);
        Data x6 = new Data("n2", "f2", 11, 12);
        Data x7 = new Data("n3", "f1", 13, 14);
        Data x8 = new Data("n4", "f1", 15, 16);
        Data x9 = new Data("n1", "f1", 5, 10);
        Data x10 = new Data("n1", "f1", 5, 2);

        dataList.add(x1);
        dataList.add(x2);
        dataList.add(x3);
        dataList.add(x4);
        dataList.add(x5);
        dataList.add(x6);
        dataList.add(x7);
        dataList.add(x8);
        dataList.add(x9);
        dataList.add(x10);

        Map<String, List<Result>> collect = dataList.stream()
                .sorted(Comparator.comparing(Data::getX).thenComparing(Data::getY))
                .collect(Collectors.groupingBy(d -> d.getSystemId() + ":" + d.getFileName(),
                        Collectors.mapping(d -> new Result(d.getX(), d.getY()), Collectors.toList())));

        Map<String, List<Result>> sortedMap = new TreeMap<String, List<Result>>(collect);

        System.out.println(sortedMap);

    }
}

Выход: {n1: f1 = [(1,2), (3,4), (5,2), (5,6), (5,10)], n1: f2 = [(7,8)], n2: f1 = [(9,10)], n2: f2 = [(11,12)], n3: f1 = [(13,14)], n4: f1 = [(15, 16)]}

Попробуйте, это работает на моей машине.

...