如何通过复杂的键对多图表进行排序?

时间:2016-08-12 14:40:51

标签: java sorting guava

我们假设我们有一个多图

Multimap<List<Integer>, String> map = HashMultimap.create();

map.put(asList(1), "a");
map.put(asList(1), "b");
map.put(asList(1), "c");
map.put(asList(2), "d");
map.put(asList(3), "e");
map.put(asList(3), "f");
map.put(asList(1), "g");
map.put(asList(1), "h");
map.put(asList(1), "i");
map.put(asList(1), "j");
map.put(asList(1), "k");
map.put(asList(1, 2), "l");
map.put(asList(1, 2), "m");
map.put(asList(1, 2), "n");
map.put(asList(1, 2), "o");
map.put(asList(3), "p");
map.put(asList(3), "q");
map.put(asList(3), "r");
map.put(asList(7,3), "s");
map.put(asList(7), "t");

map的键表示连接ID。 1已连接到与2相关联的37。我希望通过连接ID

过滤所有符号
1&2 : a,b,c,d,g,h,i,j,k,l,m,n,o
7&3 : e,f,p,q,r,s,t

我怎么能通过番石榴做到这一点?

2 个答案:

答案 0 :(得分:1)

多图的键实际上并不代表连接ID,而是连接ID列表。

你有什么:

{[1]=[a, b, c, g, h, i, j, k], [2]=[d], [3]=[p, q, r, e, f], [1, 2]=[l, m, n, o], [7]=[t], [7, 3]=[s]}

我认为你需要:

{1=[a, b, c, g, h, i, j, k, l, m, n, o], 2=[d, l, m, n, o], 3=[e, f, p, q, r, s], 7=[s, t]}

我建议您只使用Multimap<Integer, String>代替Multimap<List<Integer>, String>

Multimap<Integer, String> multimap = ArrayListMultimap.create();
multimap.put(1, "a");
multimap.put(1, "b");
multimap.put(1, "c");
multimap.put(2, "d");
multimap.put(3, "e");
multimap.put(3, "f");
multimap.put(1, "g");
multimap.put(1, "h");
multimap.put(1, "i");
multimap.put(1, "j");
multimap.put(1, "k");
multimap.put(1, "l");
multimap.put(1, "m");
multimap.put(1, "n");
multimap.put(1, "o");
multimap.put(2, "l");
multimap.put(2, "m");
multimap.put(2, "n");
multimap.put(2, "o");
multimap.put(3, "p");
multimap.put(3, "q");
multimap.put(3, "r");
multimap.put(7, "s");
multimap.put(3, "s");
multimap.put(7, "t");
System.out.println("1 & 2 : " + ImmutableSet.copyOf(Multimaps.filterKeys(multimap, i ->
        i == 1 || i == 2).values()));
System.out.println("7 & 3 : " + ImmutableSet.copyOf(Multimaps.filterKeys(multimap, i ->
        i == 7 || i == 3).values()));

示例输出:

1 & 2 : [a, b, c, g, h, i, j, k, l, m, n, o, d]
7 & 3 : [e, f, p, q, r, s, t]

答案 1 :(得分:0)

如果您使用的是Java 8或更高版本,则可以使用流。

List<String> ones = map.entries().stream()
    .filter(entry -> entry.getKey().contains(1))
    .map(Map.Entry::getValue)
    .collect(Collectors.toList());

此示例将生成一个列表,其中包含其键中包含1的所有值,但可以轻松修改为121的值和2,或者你想要的任何其他东西。这是12

List<String> onesAndTwos = map.entries().stream()
    .filter(entry -> entry.getKey().contains(1) || entry.getKey().contains(2))
    .map(Map.Entry::getValue)
    .collect(Collectors.toList());