簡體   English   中英

如何通過復雜鍵對多圖排序?

[英]How to sort a multimap by complex key?

假設我們有一個多圖

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");

映射的鍵表示連接ID。 1連接到23連接至7 我想按連接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

我如何通過番石榴做到這一點?

您的多圖鍵實際上不代表連接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]

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

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

這個例子將產生所有具有值的列表1中的關鍵,但它可以很容易地進行修改,以做那些與1212 ,或任何你想要的東西。 這是將執行12的一個:

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM