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 + -
显示快捷键?