У меня есть следующие классы:
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.