[英]How to print LinkedList Node object in reverse order
在下面的方法reverse()
,我想訪問Node
的元素並將它們添加到ArrayList
。之后,使用循環,它將以相反的順序打印。
public void reverse(){
Node e = head;
ArrayList<E> s = new ArrayList<E>();
while(e!=null){
s.add(e.element);
e= e.next;
}
for (int i = count-1; i >= 0; i--) {
System.out.print (""+s.get(i));
}
System.out.println("");
}
但是, s.add(e.element) ;
給一個錯誤。 這是Node類,
public class Node<E> {
E element;
Node<E> next;
public Node(E element){
this.element=element;
next =null;
}
}
和LinkedList類
public class LinkedListStack<E> implements Stack<E>{
Node<E> head;
Node<E> tail;
int count=-1;
public LinkedListStack() {
head=tail=null;
}
public void push(E element) {
Node<E> newNode = new Node<>(element);
if(count==-1){
head=tail=newNode;
count++;
}
else{
newNode.next=head;
head = newNode;
}
count++;
}
public void reverse(){
Node e = head;
ArrayList<E> s = new ArrayList<E>();
while(e!=null){
s.add(e.element);
e= e.next;
}
for (int i = count-1; i > 1; i--) {
System.out.print (""+s.get(i));
}
System.out.println("");
}
}
如果有人解釋添加對象的錯誤,我將不勝感激
ArrayList中的元素的詳細信息。
您將通用Node類型用作原始類型:
Node e = head;
應該
Node<E> e = head;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.