将链接列表添加到链表,JAVA

时间:2012-11-16 16:17:15

标签: java linked-list

我想设计一个链表到另一个链表,到目前为止我在MyLinkedList类中有这个方法:

public void addList(int index, E e){
        if(index == 0){
            addFirst(e);
        } else if (index >= size){
            addLast(e);
        }
        else{
            Node<E> current = head;
            for(int i = 1; i < index; i++){
                current = current.next;
            }
            Node<E> temp = current.next;
            current.next = new Node<E>(e);
            (current.next).next = temp;
            size++;
        }
    }

我坚持使用方法本身,我的主程序有两个看起来像这样的LinkedLists:

MyLinkedList<String> strings1 = new MyLinkedList<String>();
        strings1.add("java");
        strings1.add("language");
        strings1.add("cooler");
        strings1.add("noob");
        System.out.println(list1);

        MyLinkedList<String> strings2 = new MyLinkedList<String>();
        strings2.add("artistic");
        strings2.add("cereal");
        strings2.add("bowl");
        System.out.println(list2);

然后我想将string2的链表添加到string1的链表中。我该怎么办? 我想过用

strings1.addList(2, strings2); 

但它不起作用,它不会让我将strings2添加到strings1 我认为如果我完成它,输出将如下所示: java,语言,艺术,麦片,碗,冷却器,菜鸟 或类似的东西,请帮助!

3 个答案:

答案 0 :(得分:3)

您的班级中有一个接受单个节点的方法,只需根据需要多次调用第二个列表:

e.g。

void addAll(int index, MyList<> second_list)
{
  for(Object o : second_list)
  {
    addList(index, o);
    ++index;
  }
}

基于for循环的上述范围可能不起作用,除非你的类已经实现了正确的接口,我是懒惰的 - 使用你的类支持的正常迭代...

答案 1 :(得分:0)

使用方法addAll(int index, Collection c)将两个列表一起添加。

strings1.addAll(startIndex, strings2);

您还必须为您的类MyLinkedList实现List接口。 你的MyLinkedList类看起来还不是很清楚吗?

答案 2 :(得分:0)

最容易的方式......

public void insertList(int index, List<String> list) {
    Collections.reverse(list);
    for (String str : list) {
        add(index, str);
    }
}