scala反转链表 leetcode 206 Reverse Linked List

class ListNode(value:Int) {
  val v=value;
  var next:ListNode=null

}

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值