/* package whatever; // don't place package name! */
import java.util.*;
import java.lang.*;
import java.io.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;
import java.util.stream.IntStream;
/* Name of the class has to be "Main" only if the class is public. */
class Ideone
{
{
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p1",
1000),
new Endpoint
("p2",
2000)))),
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p1",
3000),
new Endpoint
("p3",
4000)))),
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p2",
5000),
new Endpoint
("p3",
6000)))),
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p1",
2000),
new Endpoint
("p2",
3000)))),
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p1",
2001),
new Endpoint
("p2",
3001)))),
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p1",
4000),
new Endpoint
("p3",
5000)))),
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p1",
4001),
new Endpoint
("p3",
5001)))),
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p2",
6000),
new Endpoint
("p3",
7000)))),
new Pair
(new ArrayList
<>(List.
of(new Endpoint
("p2",
6001),
new Endpoint
("p3",
7001)))) ));
System.
out.
println("Input: "); for (Pair p : pairs) {
}
List<CustomPair> listRes = pairs.stream()
.collect(Collectors.groupingBy(Pair::getPairKeys)) //Grouping the Pairs by the keys of the two EndPoints (key1:key2)
.entrySet().stream() //Streaming the entries of the map
.map(entry -> {
String key1
= null, key2
= null;
//Lists for the values of the CustomEndpoint
List<Integer> listValues1 = new ArrayList<>();
List<Integer> listValues2 = new ArrayList<>();
//Retrieving the keys and adding each pair's number to the respective lists
for (Pair p : entry.getValue()) {
key1 = p.getPair().get(0).getKey();
key2 = p.getPair().get(1).getKey();
listValues1.add(p.getPair().get(0).getNumber());
listValues2.add(p.getPair().get(1).getNumber());
}
//Returning the new CustomPair in place of the two grouped by Pair
return new CustomPair
(new ArrayList
<>(List.
of( new CustomEndpoint(key1, listValues1),
new CustomEndpoint(key2, listValues2))));
})
.
sorted(Comparator.
comparing(CustomPair
::getFirstPairInitialNumber
)) //Ordering the CustomPair by the beginning of their endpoint range .collect(Collectors.toList()); //Collecting the CustomPair
System.
out.
println("\nOutput: "); for (CustomPair cp : listRes) {
}
}
static class Endpoint {
this.key = key;
this.number = number;
}
return key;
}
return number;
}
@Override
public boolean equals
(Object o
) { if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Endpoint other = (Endpoint) o;
return Objects.equals(key, other.key) && Objects.equals(number, other.number);
}
@Override
public int hashCode() {
return Objects.hash(key, number);
}
@Override
return String.
format("{%s,%d}", key, number
); }
}
static class Pair {
// It will have exactly 2 entries
List<Endpoint> pair;
public Pair(List<Endpoint> pair) {
this.pair = pair;
}
public List<Endpoint> getPair() {
return pair;
}
if (pair == null || pair.size() < 2) {
return null;
}
Endpoint e1 = pair.get(0);
Endpoint e2 = pair.get(1);
return String.
format("%s:%s", e1.
getKey(), e2.
getKey()); }
@Override
public boolean equals
(Object o
) { if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Pair other = (Pair) o;
return Objects.equals(pair, other.pair);
}
@Override
public int hashCode() {
return Objects.hash(pair);
}
@Override
return String.
format("%s", pair
); }
}
static class CustomEndpoint {
private List<Integer> numbers;
public CustomEndpoint
(String key, List
<Integer
> numbers
) { this.key = key;
this.numbers = numbers;
}
public List<Integer> getNumbers() {
return numbers;
}
@Override
return String.
format("{%s,%s}", key, numbers
); }
}
static class CustomPair {
// It will have exactly 2 entries
List<CustomEndpoint> pair;
public CustomPair(List<CustomEndpoint> pair) {
this.pair = pair;
}
public Integer getFirstPairInitialNumber
() { return pair.get(0).getNumbers().get(0);
}
@Override
return pair.toString();
}
}
}
/* package whatever; // don't place package name! */

import java.util.*;
import java.lang.*;
import java.io.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;
import java.util.stream.IntStream;

/* Name of the class has to be "Main" only if the class is public. */
class Ideone
{
	public static void main (String[] args) throws java.lang.Exception
	{
		List<Pair> pairs = new ArrayList(List.of(
                new Pair(new ArrayList<>(List.of(new Endpoint("p1", 1000), new Endpoint("p2", 2000)))),
                new Pair(new ArrayList<>(List.of(new Endpoint("p1", 3000), new Endpoint("p3", 4000)))),
                new Pair(new ArrayList<>(List.of(new Endpoint("p2", 5000), new Endpoint("p3", 6000)))),
                new Pair(new ArrayList<>(List.of(new Endpoint("p1", 2000), new Endpoint("p2", 3000)))),
                new Pair(new ArrayList<>(List.of(new Endpoint("p1", 2001), new Endpoint("p2", 3001)))),
                new Pair(new ArrayList<>(List.of(new Endpoint("p1", 4000), new Endpoint("p3", 5000)))),
                new Pair(new ArrayList<>(List.of(new Endpoint("p1", 4001), new Endpoint("p3", 5001)))),
                new Pair(new ArrayList<>(List.of(new Endpoint("p2", 6000), new Endpoint("p3", 7000)))),
                new Pair(new ArrayList<>(List.of(new Endpoint("p2", 6001), new Endpoint("p3", 7001))))
        ));

        System.out.println("Input: ");
        for (Pair p : pairs) {
            System.out.println(p);
        }

        List<CustomPair> listRes = pairs.stream()
                .collect(Collectors.groupingBy(Pair::getPairKeys))  //Grouping the Pairs by the keys of the two EndPoints (key1:key2)
                .entrySet().stream()    //Streaming the entries of the map
                .map(entry -> {
                    String key1 = null, key2 = null;

                    //Lists for the values of the CustomEndpoint
                    List<Integer> listValues1 = new ArrayList<>();
                    List<Integer> listValues2 = new ArrayList<>();

                    //Retrieving the keys and adding each pair's number to the respective lists
                    for (Pair p : entry.getValue()) {
                        key1 = p.getPair().get(0).getKey();
                        key2 = p.getPair().get(1).getKey();

                        listValues1.add(p.getPair().get(0).getNumber());
                        listValues2.add(p.getPair().get(1).getNumber());
                    }

                    //Returning the new CustomPair in place of the two grouped by Pair
                    return new CustomPair(new ArrayList<>(List.of(
                            new CustomEndpoint(key1, listValues1),
                            new CustomEndpoint(key2, listValues2))));
                })
                .sorted(Comparator.comparing(CustomPair::getFirstPairInitialNumber))    //Ordering the CustomPair by the beginning of their endpoint range
                .collect(Collectors.toList());  //Collecting the CustomPair

        System.out.println("\nOutput: ");
        for (CustomPair cp : listRes) {
            System.out.println(cp);
        }
    }

    static class Endpoint {
        private String key;
        private Integer number;

        public Endpoint(String key, Integer number) {
            this.key = key;
            this.number = number;
        }

        public String getKey() {
            return key;
        }

        public Integer getNumber() {
            return number;
        }

        @Override
        public boolean equals(Object o) {
            if (this == o) return true;
            if (o == null || getClass() != o.getClass()) return false;
            Endpoint other = (Endpoint) o;
            return Objects.equals(key, other.key) && Objects.equals(number, other.number);
        }

        @Override
        public int hashCode() {
            return Objects.hash(key, number);
        }

        @Override
        public String toString() {
            return String.format("{%s,%d}", key, number);
        }
    }

    static class Pair {
        // It will have exactly 2 entries
        List<Endpoint> pair;

        public Pair(List<Endpoint> pair) {
            this.pair = pair;
        }

        public List<Endpoint> getPair() {
            return pair;
        }

        public String getPairKeys() {
            if (pair == null || pair.size() < 2) {
                return null;
            }

            Endpoint e1 = pair.get(0);
            Endpoint e2 = pair.get(1);

            return String.format("%s:%s", e1.getKey(), e2.getKey());
        }

        @Override
        public boolean equals(Object o) {
            if (this == o) return true;
            if (o == null || getClass() != o.getClass()) return false;
            Pair other = (Pair) o;
            return Objects.equals(pair, other.pair);
        }

        @Override
        public int hashCode() {
            return Objects.hash(pair);
        }

        @Override
        public String toString() {
            return String.format("%s", pair);
        }
    }

    static class CustomEndpoint {
        private String key;
        private List<Integer> numbers;

        public CustomEndpoint(String key, List<Integer> numbers) {
            this.key = key;
            this.numbers = numbers;
        }

        public List<Integer> getNumbers() {
            return numbers;
        }

        @Override
        public String toString() {
            return String.format("{%s,%s}", key, numbers);
        }
    }

    static class CustomPair {
        // It will have exactly 2 entries
        List<CustomEndpoint> pair;

        public CustomPair(List<CustomEndpoint> pair) {
            this.pair = pair;
        }

        public Integer getFirstPairInitialNumber() {
            return pair.get(0).getNumbers().get(0);
        }

        @Override
        public String toString() {
            return pair.toString();
        }
    }
}
Input:
[{p1,1000}, {p2,2000}]
[{p1,3000}, {p3,4000}]
[{p2,5000}, {p3,6000}]
[{p1,2000}, {p2,3000}]
[{p1,2001}, {p2,3001}]
[{p1,4000}, {p3,5000}]
[{p1,4001}, {p3,5001}]
[{p2,6000}, {p3,7000}]
[{p2,6001}, {p3,7001}]
Output:
[{p1,[1000, 2000, 2001]}, {p2,[2000, 3000, 3001]}]
[{p1,[3000, 4000, 4001]}, {p3,[4000, 5000, 5001]}]
[{p2,[5000, 6000, 6001]}, {p3,[6000, 7000, 7001]}]