尝试在单链表的末尾插入,但是我在输出中发现了一些错误。这是我的代码:
public class LinkRemove
{
private static final int N = 5;
public static void main(String[] args)
{
Scanner sx = new Scanner(System.in);
Node first = new Node();
Node tail = new Node();
first=tail;
for(int i=0;i<N;i++)
{
Node current = new Node();
if(tail==null)
{
tail.data = sx.nextInt();
}
else
{
current.data = sx.nextInt();
while(tail.link!=null)
tail = tail.link;
tail.link = current;
}
}
for(Node d = first;d.link!=null;d=d.link)
System.out.println(d.data);
}
private static class Node
{
int data;
Node link;
}
}
现在问题是,当我提供输入时:
2 4 6 8 10
我的输出为:
0 2 4 6 8
可能导致这种情况的原因是什么?为什么我在开始时会得到0
?
请给出一个描述性的答案,谢谢!
答案 0 :(得分:0)
第一个0来自节点(Node tail = new Node();
)中字段的默认值。实际上,您希望将其设置为null
而不是new Node()
。同样适用于first
。事实上,为什么不写信:
Node tail = null;
Node first = tail;
像迈克所说,你的终止条件不正确。
此外,
if(tail==null)
{
tail.data = sx.nextInt();
}
根本没有意义。如果代码到达tail.data = ...
,则它将是NullPointerException。你究竟想做什么?
答案 1 :(得分:0)
我稍微修改了你的代码
public static void main(String[] args) {
Scanner sx = new Scanner(System.in);
Node first = null;
Node tail = null;
for (int i = 0; i < N; i++) {
Node current = new Node();
current.data = sx.nextInt();
if(first == null) {
first = current;
tail = first;
} else {
tail.link = current;
tail = current;
}
}
for (Node d = first; d != null; d = d.link)
System.out.println(d.data);
}
用于在节点中设置数据的逻辑不正确。首先,您必须设置第一个节点并设置tail = first 然后,将新节点添加到tail:tail.link = current。
希望这有帮助。
答案 2 :(得分:0)
试试这个
Scanner sx = new Scanner(System.in);
Node first = null;
Node tail = null;
for (int i = 0; i < N; i++)
{
Node current = new Node();
current.data = sx.nextInt();
if (tail == null)
{
first = tail = current;
}
else
{
tail = tail.link = current;
}
}
for(Node d = first; d != null; d = d.link)
System.out.println(d.data);