java - 返回包含另一个链表中的键的链表

标签 java linked-list hashmap key-value nodelist

我遇到以下问题。我有一个链接列表或位置列表,其中包含名为 Entry 的对象。每个条目存储一个键和一个值对。我想创建另一个链接列表以从该列表中获取键。我想出了一种方法来做到这一点,但是由于某种原因,当我打印 key 列表时,我添加的它们的顺序没有被表示出来。我有以下两种方法:

public PositionalList1<K> keySet() //I prnted position by position while adding and it worked. I also tested addAfter with positionalList1 class and it worked
{
    PositionInterface<Entry> iterator = map.first(); //gets first position in the Entry List
    PositionInterface<K> first = keyList.addFirst((K)iterator.getData().getKey()); //adds to list containing just keys the key from the Entry list(getData is just a method that returns whatever object is stored at the node, in this case a Entry Object)
    iterator = map.after(iterator); //go to next node in Entry list

    for(int i=0;i<size-1;i++) //get rest of keys
    {
        PositionInterface<K> p = keyList.addAfter(first,(K)iterator.getData().getKey());
        iterator = map.after(iterator);

    }
    return keyList;
}

public void printKeySet(PositionalList1 list) //print key list
{
    PositionInterface p = list.first();
    for(int i=0; i<list.size();i++)
    {
        System.out.println("Key : " + p.getData());
        p = list.after(p);
    }
}

keySet() 方法返回仅包含键的列表,而 printKeySet 则获取 KeySet() 的结果并打印整个键列表。我已经使用以下主程序对此进行了测试:

OrderedMapL<Integer,String> map2 = new OrderedMapL<Integer,String>();
    map2.put(2,"A");//adds (2,A)
    map2.put(5,"B");//adds(5,B)
    map2.put(1,"C");//adds(1,C)
    map2.put(4,"D");//adds(4,D)
    map2.put(3,"E");//adds(3,E)
    map2.remove(2); //removes (2,A)

这导致了 (1,C) (2,A) .. 等的有序列表,并且条目本身按此顺序打印良好。调用以下命令时会出现问题:

PositionalList1<Integer> keyList = map2.keySet();
map2.printKeySet(keyList);

由于某种原因,按键按顺序打印:1,5,4,3而不是1,3,4,5,我不知道为什么。任何帮助将不胜感激。

最佳答案

问题出在这一行:

PositionInterface<K> p = keyList.addAfter(first,(K)iterator.getData().getKey());

您不应该在first之后添加。这就是为什么你会得到错误的顺序。

如果键是 1, 3, 4, 5 那么您将像这样添加它:

  1. 添加 1 作为第一个元素 1
  2. 在第一个元素后添加 3 1 3
  3. 在第一个元素后添加 4 1 4 3
  4. 在第一个元素后添加 5 1 5 4 3

这是因为您将其添加到第一个元素之后。

如果我正确理解您的代码,您应该像这样更改它:

// I suspect that #addFirst method returns added list element
PositionInterface<K> last = keyList.addFirst((K) iterator.getData().getKey());
iterator = map.after(iterator);

for(int i = 0; i < size - 1; i++)
{
    // I suspect that #addAfter method returns added list element
    PositionInterface<K> last = keyList.addAfter(last, (K) iterator.getData().getKey());
    iterator = map.after(iterator);

}

关于java - 返回包含另一个链表中的键的链表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40522080/

相关文章:

java - JSP - 文件名、目录名或卷标语法不正确

c++ - 无法从 'Node<T> *' 推断出 'int' 的模板参数

java - 如何从ListArray中获取数据(键,值)

java - 将 Jasper 报告中的数字转换为字母

java - 到子资源的 REST 映射

java - 在selenium中使用safari驱动程序的图像位置

c++ - 如何使用智能指针为单链表实现复制构造函数

java - 如何实现双向链表的 get Previous() 方法?

java - 员工商店的编辑方法。(使用Hashmap)

java - 可以将 Map<Integer, ArrayList<String>> 中的值与 ArrayList<String> 进行比较