首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LinkedList temp.next和temp?

LinkedList temp.next和temp?
EN

Stack Overflow用户
提问于 2011-12-09 14:39:55
回答 4查看 1.7K关注 0票数 1

所以我正在练习一些链表问题,我一直在搞混,假设我们做//这是一个只有头的单链表

代码语言:javascript
复制
// what is the difference between 

ListNode temp = head;
while( temp != null ) {
    temp = temp.next ; 
} 

while( temp.next != null ) {
    temp = temp.next ; 
} 

再说一次,这两者之间的区别是什么?如果你能向我解释这一点,我将不胜感激。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-12-09 14:42:55

第一个示例在temp == null时终止,这意味着temp在循环后将具有空值,对您没有太大用处,尽管对于处理列表中的项来说,这是一种非常有效的方法。

第二个示例将在temp.next == null但temp本身实际有一个值时停止,在这种情况下,它将是对列表尾部的引用,如果您还想在列表中添加其他内容,这将非常有用。

正如其他一些人指出的那样,如果temp为null,则第二个将导致null取消引用异常,但只有在处理循环之前temp为null时,才会出现问题,因此可以使用条件来避免这种情况。

票数 2
EN

Stack Overflow用户

发布于 2011-12-09 14:42:20

第一个会比第二个晚停止一个链接,所以如果你想处理每一个节点,那么就使用第一个。

票数 1
EN

Stack Overflow用户

发布于 2011-12-09 14:42:57

如果第一次检查while条件时temp本身为null,则第二个可能会得到NullPointerException。第一个是安全的,不会出现这样的异常。

第二个元素将以链表中的最后一个元素结束,而第一个元素将以null结束。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8441959

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档