viewtest1.scala

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

SCALA
43
字号
package testtrait Ordered[a] {  def < (x: a): boolean}object O {  implicit def view (x: String): Ordered[String] = new Ordered[String] {    def < (y: String) = x.compareTo(y) < 0  }}object Empty extends Tree[Nothing]case class Node[c <% Ordered[c]](elem: c, l: Tree[c], r: Tree[c]) extends Tree[c]abstract class Tree[+a <% Ordered[a]] {  def insert[b >: a <% Ordered[b]](x: b): Tree[b] = this match {    case Empty =>      new Node(x, Empty, Empty)    case Node(elem, l, r) =>      if (x == elem) this      else if (x < elem) Node(elem, l insert x, r)      else Node(elem, l, r insert x)  }  def elements: List[a] = this match {    case Empty => List()    case Node(elem, l, r) =>      l.elements ::: List(elem) ::: r.elements  }}object Test {  import O.view  def main(args: Array[String]) = {    var t: Tree[String] = Empty    for (val s <- args) {      t = t insert s    }    Console.println(t.elements)  }}

⌨️ 快捷键说明

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