[英]how to access 2 keys in a hashmap in same loop?
我正在嘗試使用Map.Entry
在同一 for 循環中訪問key1
和key2
。 但有時entry.getKey()
只返回當前鍵。 如何同時訪問 2 個密鑰?
for(Map.Entry<Long, NodeDisjoint1> entry : map.entrySet()) {
long parent1 = findSet(entry.getKey());
long parent2 = findSet(entry.getKey());
}
執行以下操作:
Set<Map.Entry<Long, NodeDisjoint1>> entrySet = map.entrySet();
List<Map.Entry<Long, NodeDisjoint1>> entryList = new ArrayList<>(entrySet);
ListIterator<Map.Entry<Long, NodeDisjoint1>> itr = entryList.listIterator();
long parent1, parent2;
while(itr.hasNext()) {
parent1 = findSet((Entry)itr.next().getKey());
if(itr.hasNext()) {
parent2 = findSet((Entry)itr.next().getKey());
itr.previous();
}
}
import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.ListIterator;
import java.util.Set;
public class Main {
public static void main(String[] args) {
Set<Integer> set = new LinkedHashSet<Integer>(Arrays.asList(10, 20, 30, 40));
List<Integer> list = new ArrayList<Integer>(set);
ListIterator<Integer> itr = list.listIterator();
while (itr.hasNext()) {
System.out.println(itr.next());
if (itr.hasNext()) {
System.out.println(itr.next());
itr.previous();
}
}
}
}
Output:
10
20
20
30
30
40
40
如有任何疑問/問題,請隨意。
使用1 個 ENTRYSET ,您只能訪問 1 個鍵和 1 個值
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.