singlelinkedlist.scala

来自「JAVA 语言的函数式编程扩展」· SCALA 代码 · 共 63 行

SCALA
63
字号
/*                     __                                               *\**     ________ ___   / /  ___     Scala API                            ****    / __/ __// _ | / /  / _ |    (c) 2003-2006, LAMP/EPFL             ****  __\ \/ /__/ __ |/ /__/ __ |                                         **** /____/\___/_/ |_/____/_/ | |                                         ****                          |/                                          **\*                                                                      */// $Id: SingleLinkedList.scala 11911 2007-06-05 15:57:59Z odersky $package scala.collection.mutable/** This extensible class may be used as a basis for implementing linked *  list. Type variable <code>A</code> refers to the element type of the *  list, type variable <code>This</code> is used to model self types of *  linked lists. * *  @author  Matthias Zenger *  @version 1.0, 08/07/2003 */abstract class SingleLinkedList[A, This >: Null <: SingleLinkedList[A, This]]         extends AnyRef with Seq[A]{ self: This =>  var elem: A  var next: This  def length: Int = 1 + (if (next eq null) 0 else next.length)  def append(that: This): Unit =    if (next eq null) next = that else next.append(that)  def insert(that: This): Unit = if (that ne null) {    that.append(next)    next = that  }  def apply(n: Int): A =    if (n == 0) elem    else if (next eq null) throw new IndexOutOfBoundsException("unknown element")    else next.apply(n - 1)  def get(n: Int): Option[A] =    if (n == 0) Some(elem)    else if (next eq null) None    else next.get(n - 1)  override def elements: Iterator[A] = new Iterator[A] {    var elems = SingleLinkedList.this    def hasNext = (elems ne null)    def next = {      val res = elems.elem      elems = elems.next      res;    }  }  override def toList: List[A] = elements toList}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?