您的位置:首页 > 其它

scala反转链表 leetcode 206 Reverse Linked List

2017-08-13 22:50 986 查看
class ListNode(value:Int) {
val v=value;
var next:ListNode=null
}def reverse(l1: ListNode): ListNode = {var l2=l1;var pre:ListNode=nullwhile (l2!=null){val tmp=l2.nextl2.next=prepre=l2l2=tmp;}pre}
在scala中,参数是val,因此只能将其赋值给var l2,再用tmp临时变量储存下一个节点,用l2=tmp将指针后移,实现对链表遍历的功能。
同时,将l2的next设置成pre,在链表的遍历过程中,l2指向前一个节点,再将当前节点赋值给pre,遍历完成后,pre的每一个节点都是
指向l2的前一个节点,pre的最后一个节点(在遍历第一个节点时)指向了null。

                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  leetcode 链表