首页 > 解决方案 > 如何在同一循环中访问哈希图中的 2 个键?

问题描述

我正在key1尝试key2使用Map.Entry. 但一次entry.getKey()只返回当前键。如何同时访问 2 个密钥?

for(Map.Entry<Long, NodeDisjoint1> entry : map.entrySet()) {
    long parent1 = findSet(entry.getKey());
    long parent2 = findSet(entry.getKey());
}

标签: javahashmap

解决方案


执行以下操作:

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();
            }
        }
    }
}

输出:

10
20
20
30
30
40
40

如有任何疑问/问题,请随意。


推荐阅读