Scala 中的函數式編程基礎(三)

 

 

主要來自 Scala 語言發明人 Martin Odersky 教授的 Coursera 課程 《Functional Programming Principles in Scala》java


3. Data and Abstraction

3.1 Class Hierarchies

這一集字幕不一樣步-,-,聽得有點費力!python

類的概念和其餘語言裏面很類似,基類,子類,父類啥的叫法差很少。在 Scala 中,全部用戶自定義的類都是另一個類的子類,若是沒有顯式給定父類,java 裏面默認繼承 java.lang,scala 裏面是 Object。不管基類中的方法有沒有具體實現,子類均可以用 override 從新定義,回想起以前強大的 toString 了嗎?編程

舉一個二叉樹的例子:api

package week3

object insets {
  val t1 = new NonEmpty(3, Empty, Empty)          //> t1 : week3.NonEmpty = {.3.}
  val t2 = t1 incl 4                              //> t2 : week3.IntSet = {.3{.4.}}
  val t3 = new NonEmpty(5, Empty, Empty)          //> t3 : week3.NonEmpty = {.5.}
  t2 union t3                                     //> res0: week3.IntSet = {{{.3.}4.}5.}
}

abstract class IntSet {  // 抽象類做爲基類,沒法實例化,定義了三個接口
  def contains(x: Int): Boolean // 查找是否包含 x
  def incl(x: Int): IntSet // 若是 x 不存在,將 x 放入二叉樹中
  def union(x: IntSet): IntSet  // 兩棵樹融合
  }

object Empty extends IntSet { // Empty 是 IntSet 的 subclass,`object` 表示單例模式,全部空節點均可以用一個對象來表示
  def contains(x: Int): Boolean = false
  def incl(x: Int): IntSet = new NonEmpty(x, Empty, Empty)
  def union(other: IntSet): IntSet = other
  override def toString = "." // 空節點打印"."
}

class NonEmpty(elem: Int, left: IntSet, right: IntSet) extends IntSet {
  def contains(x: Int): Boolean =
    if (x < elem) left contains x
    else if (x > elem) right contains x
    else true

  def incl(x: Int): IntSet =
    // 實際上建立了一個新樹,新樹和舊樹共用未改變的子樹
    // 這個叫 persistent data structure,是把函數式編程擴展到 collections 的關鍵之一
    // 反正他是這麼說的 `-,-`
    if (x < elem) new NonEmpty(elem, left incl x, right) // 一重一重地複製節點
    else if (x > elem) new NonEmpty(elem, left, right incl x)
    else this

  def union(other: IntSet): IntSet =
    ((left union right) union other) incl elem  // 

  override def toString = "{" + left + elem + right + "}" //強大的遞歸啊
}

3.2 How Classes Are Organized

沒學過 java,估計和 java 中 package 管理同樣。ssh

在源碼最頂端寫上 package week3 表示這個文件的 object 或者 class 屬於這個包。要使用某一個類,能夠在源碼中用全名 week3.classA,也能夠像 python 同樣在最開始 import,源碼中間用類名:ide

  • import week3.classA:導入類 classA
  • import week3.{classA, classB}:導入兩個類
  • import week3._ :導入包全部(通配符導入方法)

除了從包導入,還能夠從 object 導入。全部 Scala 程序默認導入一些 entities,好比 scala 中的 Int,java.lang 中的 Object,scala.Predef 中的斷言等。更多信息能夠查看 scala 的標準庫函數式編程

在 java 和 scala 中,一個類只能有一個父類(單繼承),如何實現多繼承,scala 中採用 traits。trait 像 java 裏面的接口,偏抽象,可是更強大,能夠包含 field 和具體方法,可是不能有value參數。子類可只能繼承一個父類,可是能夠繼承任意多個 traits,例如:class Square extends Shape with Planar with Moveble函數

scala 類型結構以下,實線表示繼承,虛線表示隱式轉化。學習

  • Any是全部類型的基本類,包含的方法有:‘==’,‘!=’,‘equals’,‘hashCode’,‘toString’
  • AnyVal是數值類型的基本類。
  • AnyRef是全部引用類型的基本類,也是 java.lang.Object 的別名。
  • Nothing是全部類的子類型。主要做用是異常類與collection中的一個空元素。
  • Null 是全部類的子類型。可是與 AnyVal 的子類型不兼容。

Q:if (true) 1 else False 的返回類型是什麼?
A:int 和 boolean 類型,返回父類 AnyVal。測試

3.3 Polymorphism

Polymorphism 意味着函數能夠以多種類型出現。一張 PPT 總結 Polymorphism:

假設咱們要創建一個 list 類,它可能包含了不一樣的數據類型(整數,布爾,list自身類型等),例子以下:

這時須要用泛型來表示。新建一個package叫week4,在其中新建一個 trait。它的兩個‘子類’分別爲 Cons 和 Nil,分別表示含有元素的節點和空節點。

package week4

// [T] 是類型參數,好比int,double之類。是泛型編程的基礎
trait List[T] {
  def isEmpty: Boolean
  def head: T
  def tail: List[T]
}

class Cons[T](val head: T, val tail: List[T]) extends List[T] {
  def isEmpty = false
  // head 和 tail 已經在初始化中實現
}

class Nil[T] extends List[T] {
  def isEmpty = true
  def head: Nothing = throw new NoSuchElementException("Nil.head")
  // Nothing 是任何類型的子類,因此也是 T 的子類
  def tail: Nothing = throw new NoSuchElementException("Nil.tail")
}

在 week4 中新建一個 scala worksheet,測試一下上述代碼:

package week4

import week4._

object nth {
  // 建立一個含有一個元素的 list
  def singleton[T](elem: T) = new Cons(elem, new Nil)
 //> singleton: [T](elem: T)week4.Cons[T]
  singleton[Int](3)         //> res0: week4.Cons[Int] = week4.Cons@71be98f5
  singleton(3) // 編譯器能夠從 3 推到出 T 是 Int 

  // 尋找 list 中的第 n 個元素
  def nth[T](n: Int, xs: List[T]): T =
 if (xs.isEmpty) throw new IndexOutOfBoundsException
 else if (n == 0) xs.head
 else nth(n - 1, xs.tail) //> nth: [T](n: Int, xs: week4.List[T])T

  // 建立一個 list  = [1, 2, 3]
  val list = new Cons(1, new Cons(2, new Cons(3, new Nil)))
  nth(2, list)         //> res2: Int = 3
}

小記

這裏是課程前四次的大概內容,由於第一次課是教你怎麼安裝,因此實際內容只有三次課,後面還有四次課。整體來講,函數式編程給人不少啓發,可是若是不是真正須要用,也不宜佔用太多時間去學習。暑假要去實習了,等下學期再學吧。

Scala%20%u4E2D%u7684%u51FD%u6570%u5F0F%u7F16%u7A0B%u57FA%u7840%28%u4E09%29%0A%3D%3D%3D%0A%0A@%28scala%29%5B%u5B66%u4E60%u7B14%u8BB0%7CCoursera%5D%0A%0A%3E%20%u4E3B%u8981%u6765%u81EA%20Scala%20%u8BED%u8A00%u53D1%u660E%u4EBA%20Martin%20Odersky%20%u6559%u6388%u7684%20Coursera%20%u8BFE%u7A0B%20**%u300AFunctional%20Programming%20Principles%20in%20Scala%u300B**%u3002%0A%0A---%0A%0A%23%23%203.%20Data%20and%20Abstraction%0A%23%23%23%203.1%20Class%20Hierarchies%0A%u8FD9%u4E00%u96C6%u5B57%u5E55%u4E0D%u540C%u6B65%60-%2C-%60%uFF0C%u542C%u5F97%u6709%u70B9%u8D39%u529B%uFF01%0A%0A%u7C7B%u7684%u6982%u5FF5%u548C%u5176%u4ED6%u8BED%u8A00%u91CC%u9762%u5F88%u76F8%u4F3C%uFF0C%u57FA%u7C7B%uFF0C%u5B50%u7C7B%uFF0C%u7236%u7C7B%u5565%u7684%u53EB%u6CD5%u5DEE%u4E0D%u591A%u3002%u5728%20Scala%20%u4E2D%uFF0C%u6240%u6709%u7528%u6237%u81EA%u5B9A%u4E49%u7684%u7C7B%u90FD%u662F%u53E6%u5916%u4E00%u4E2A%u7C7B%u7684%u5B50%u7C7B%uFF0C%u5982%u679C%u6CA1%u6709%u663E%u5F0F%u7ED9%u5B9A%u7236%u7C7B%uFF0Cjava%20%u91CC%u9762%u9ED8%u8BA4%u7EE7%u627F%20java.lang%uFF0Cscala%20%u91CC%u9762%u662F%20Object%u3002%u65E0%u8BBA%u57FA%u7C7B%u4E2D%u7684%u65B9%u6CD5%u6709%u6CA1%u6709%u5177%u4F53%u5B9E%u73B0%uFF0C%u5B50%u7C7B%u90FD%u53EF%u4EE5%u7528%20%60override%60%20%u91CD%u65B0%u5B9A%u4E49%uFF0C%u56DE%u60F3%u8D77%u4E4B%u524D%u5F3A%u5927%u7684%20%60toString%60%20%u4E86%u5417%uFF1F%0A%0A%u4E3E%u4E00%u4E2A%u4E8C%u53C9%u6811%u7684%u4F8B%u5B50%uFF1A%0A%60%60%60scala%0Apackage%20week3%0A%0Aobject%20insets%20%7B%0A%20%20val%20t1%20%3D%20new%20NonEmpty%283%2C%20Empty%2C%20Empty%29%20%20%20%20%20%20%20%20%20%20//%3E%20t1%20%20%3A%20week3.NonEmpty%20%3D%20%7B.3.%7D%0A%20%20val%20t2%20%3D%20t1%20incl%204%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20//%3E%20t2%20%20%3A%20week3.IntSet%20%3D%20%7B.3%7B.4.%7D%7D%0A%20%20val%20t3%20%3D%20new%20NonEmpty%285%2C%20Empty%2C%20Empty%29%20%20%20%20%20%20%20%20%20%20//%3E%20t3%20%20%3A%20week3.NonEmpty%20%3D%20%7B.5.%7D%0A%20%20t2%20union%20t3%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20//%3E%20res0%3A%20week3.IntSet%20%3D%20%7B%7B%7B.3.%7D4.%7D5.%7D%0A%7D%0A%0Aabstract%20class%20IntSet%20%7B%20%20//%20%u62BD%u8C61%u7C7B%u4F5C%u4E3A%u57FA%u7C7B%uFF0C%u65E0%u6CD5%u5B9E%u4F8B%u5316%uFF0C%u5B9A%u4E49%u4E86%u4E09%u4E2A%u63A5%u53E3%0A%20%20def%20contains%28x%3A%20Int%29%3A%20Boolean%20//%20%u67E5%u627E%u662F%u5426%u5305%u542B%20x%0A%20%20def%20incl%28x%3A%20Int%29%3A%20IntSet%20//%20%u5982%u679C%20x%20%u4E0D%u5B58%u5728%uFF0C%u5C06%20x%20%u653E%u5165%u4E8C%u53C9%u6811%u4E2D%0A%20%20def%20union%28x%3A%20IntSet%29%3A%20IntSet%20%20//%20%u4E24%u68F5%u6811%u878D%u5408%0A%20%20%7D%0A%20%20%0Aobject%20Empty%20extends%20IntSet%20%7B%20//%20Empty%20%u662F%20IntSet%20%u7684%20subclass%uFF0C%60object%60%20%u8868%u793A%u5355%u4F8B%u6A21%u5F0F%uFF0C%u6240%u6709%u7A7A%u8282%u70B9%u90FD%u53EF%u4EE5%u7528%u4E00%u4E2A%u5BF9%u8C61%u6765%u8868%u793A%0A%20%20def%20contains%28x%3A%20Int%29%3A%20Boolean%20%3D%20false%0A%20%20def%20incl%28x%3A%20Int%29%3A%20IntSet%20%3D%20new%20NonEmpty%28x%2C%20Empty%2C%20Empty%29%0A%20%20def%20union%28other%3A%20IntSet%29%3A%20IntSet%20%3D%20other%0A%20%20override%20def%20toString%20%3D%20%22.%22%20//%20%u7A7A%u8282%u70B9%u6253%u5370%22.%22%0A%7D%0A%0Aclass%20NonEmpty%28elem%3A%20Int%2C%20left%3A%20IntSet%2C%20right%3A%20IntSet%29%20extends%20IntSet%20%7B%0A%20%20def%20contains%28x%3A%20Int%29%3A%20Boolean%20%3D%0A%20%20%20%20if%20%28x%20%3C%20elem%29%20left%20contains%20x%0A%20%20%20%20else%20if%20%28x%20%3E%20elem%29%20right%20contains%20x%0A%20%20%20%20else%20true%0A%20%20%20%20%0A%20%20def%20incl%28x%3A%20Int%29%3A%20IntSet%20%3D%0A%20%20%20%20//%20%u5B9E%u9645%u4E0A%u521B%u5EFA%u4E86%u4E00%u4E2A%u65B0%u6811%uFF0C%u65B0%u6811%u548C%u65E7%u6811%u5171%u7528%u672A%u6539%u53D8%u7684%u5B50%u6811%0A%20%20%20%20//%20%u8FD9%u4E2A%u53EB%20persistent%20data%20structure%2C%u662F%u628A%u51FD%u6570%u5F0F%u7F16%u7A0B%u6269%u5C55%u5230%20collections%20%u7684%u5173%u952E%u4E4B%u4E00%0A%20%20%20%20//%20%u53CD%u6B63%u4ED6%u662F%u8FD9%u4E48%u8BF4%u7684%20%60-%2C-%60%0A%20%20%20%20if%20%28x%20%3C%20elem%29%20new%20NonEmpty%28elem%2C%20left%20incl%20x%2C%20right%29%20//%20%u4E00%u91CD%u4E00%u91CD%u5730%u590D%u5236%u8282%u70B9%0A%20%20%20%20else%20if%20%28x%20%3E%20elem%29%20new%20NonEmpty%28elem%2C%20left%2C%20right%20incl%20x%29%0A%20%20%20%20else%20this%0A%20%20%20%20%0A%20%20def%20union%28other%3A%20IntSet%29%3A%20IntSet%20%3D%0A%20%20%20%20%28%28left%20union%20right%29%20union%20other%29%20incl%20elem%20%20//%20%0A%20%20%20%20%0A%20%20override%20def%20toString%20%3D%20%22%7B%22%20+%20left%20+%20elem%20+%20right%20+%20%22%7D%22%20//%u5F3A%u5927%u7684%u9012%u5F52%u554A%0A%7D%0A%0A%60%60%60%0A%0A%23%23%23%203.2%20How%20Classes%20Are%20Organized%0A%u6CA1%u5B66%u8FC7%20java%uFF0C%u4F30%u8BA1%u548C%20java%20%u4E2D%20package%20%u7BA1%u7406%u4E00%u6837%u3002%0A%0A%u5728%u6E90%u7801%u6700%u9876%u7AEF%u5199%u4E0A%20%60package%20week3%60%20%u8868%u793A%u8FD9%u4E2A%u6587%u4EF6%u7684%20object%20%u6216%u8005%20class%20%u5C5E%u4E8E%u8FD9%u4E2A%u5305%u3002%u8981%u4F7F%u7528%u67D0%u4E00%u4E2A%u7C7B%uFF0C%u53EF%u4EE5%u5728%u6E90%u7801%u4E2D%u7528%u5168%u540D%20%60week3.classA%60%uFF0C%u4E5F%u53EF%u4EE5%u50CF%20python%20%u4E00%u6837%u5728%u6700%u5F00%u59CB%20import%uFF0C%u6E90%u7801%u4E2D%u95F4%u7528%u7C7B%u540D%uFF1A%0A-%20import%20week3.classA%uFF1A%u5BFC%u5165%u7C7B%20classA%0A-%20import%20week3.%7BclassA%2C%20classB%7D%uFF1A%u5BFC%u5165%u4E24%u4E2A%u7C7B%0A-%20import%20week3._%20%uFF1A%u5BFC%u5165%u5305%u6240%u6709%uFF08%u901A%u914D%u7B26%u5BFC%u5165%u65B9%u6CD5%uFF09%0A%0A%u9664%u4E86%u4ECE%u5305%u5BFC%u5165%uFF0C%u8FD8%u53EF%u4EE5%u4ECE%20object%20%u5BFC%u5165%u3002%u6240%u6709%20Scala%20%u7A0B%u5E8F%u9ED8%u8BA4%u5BFC%u5165%u4E00%u4E9B%20entities%uFF0C%u6BD4%u5982%20scala%20%u4E2D%u7684%20Int%uFF0Cjava.lang%20%u4E2D%u7684%20Object%uFF0Cscala.Predef%20%u4E2D%u7684%u65AD%u8A00%u7B49%u3002%u66F4%u591A%u4FE1%u606F%u53EF%u4EE5%u67E5%u770B%20scala%20%u7684%5B%u6807%u51C6%u5E93%5D%28http%3A//www.scala-lang.org/files/archive/api/current/%23package%29%u3002%0A%0A%u5728%20java%20%u548C%20scala%20%u4E2D%uFF0C%u4E00%u4E2A%u7C7B%u53EA%u80FD%u6709%u4E00%u4E2A%u7236%u7C7B%uFF08%u5355%u7EE7%u627F%uFF09%uFF0C%u5982%u4F55%u5B9E%u73B0%u591A%u7EE7%u627F%uFF0Cscala%20%u4E2D%u91C7%u7528%20traits%u3002trait%20%u50CF%20java%20%u91CC%u9762%u7684%u63A5%u53E3%uFF0C%u504F%u62BD%u8C61%uFF0C%u4F46%u662F%u66F4%u5F3A%u5927%uFF0C%u53EF%u4EE5%u5305%u542B%20field%20%u548C%u5177%u4F53%u65B9%u6CD5%uFF0C%u4F46%u662F%u4E0D%u80FD%u6709value%u53C2%u6570%u3002%u5B50%u7C7B%u53EF%u53EA%u80FD%u7EE7%u627F%u4E00%u4E2A%u7236%u7C7B%uFF0C%u4F46%u662F%u53EF%u4EE5%u7EE7%u627F%u4EFB%u610F%u591A%u4E2A%20traits%uFF0C%u4F8B%u5982%uFF1A%60class%20Square%20extends%20Shape%20with%20Planar%20with%20Moveble%60%u3002%0A%0Ascala%20%u7C7B%u578B%u7ED3%u6784%u5982%u4E0B%uFF0C%u5B9E%u7EBF%u8868%u793A%u7EE7%u627F%uFF0C%u865A%u7EBF%u8868%u793A%u9690%u5F0F%u8F6C%u5316%u3002%0A-%20%60Any%60%u662F%u6240%u6709%u7C7B%u578B%u7684%u57FA%u672C%u7C7B%uFF0C%u5305%u542B%u7684%u65B9%u6CD5%u6709%uFF1A%u2018%3D%3D%u2019%uFF0C%u2018%21%3D%u2019%uFF0C%u2018equals%u2019%uFF0C%u2018hashCode%u2019%uFF0C%u2018toString%u2019%0A-%20%60AnyVal%60%u662F%u6570%u503C%u7C7B%u578B%u7684%u57FA%u672C%u7C7B%u3002%0A-%20%60AnyRef%60%u662F%u6240%u6709%u5F15%u7528%u7C7B%u578B%u7684%u57FA%u672C%u7C7B%uFF0C%u4E5F%u662F%20java.lang.Object%20%u7684%u522B%u540D%u3002%0A-%20%60Nothing%60%u662F%u6240%u6709%u7C7B%u7684%u5B50%u7C7B%u578B%u3002%u4E3B%u8981%u4F5C%u7528%u662F%u5F02%u5E38%u7C7B%u4E0Ecollection%u4E2D%u7684%u4E00%u4E2A%u7A7A%u5143%u7D20%u3002%0A-%20%60Null%60%20%u662F%u6240%u6709%u7C7B%u7684%u5B50%u7C7B%u578B%u3002%u4F46%u662F%u4E0E%20AnyVal%20%u7684%u5B50%u7C7B%u578B%u4E0D%u517C%u5BB9%u3002%0A%21%5BAlt%20text%5D%28./classhierarchy.png%29%0A%0A**Q%uFF1A**%60if%20%28true%29%201%20else%20False%60%20%u7684%u8FD4%u56DE%u7C7B%u578B%u662F%u4EC0%u4E48%uFF1F%0A**A%uFF1A**int%20%u548C%20boolean%20%u7C7B%u578B%uFF0C%u8FD4%u56DE%u7236%u7C7B%20AnyVal%u3002%0A%0A%23%23%23%203.3%20Polymorphism%0A%0APolymorphism%20%u610F%u5473%u7740%u51FD%u6570%u53EF%u4EE5%u4EE5%u591A%u79CD%u7C7B%u578B%u51FA%u73B0%u3002%u4E00%u5F20%20PPT%20%u603B%u7ED3%20Polymorphism%uFF1A%0A%21%5BAlt%20text%5D%28./Selection_006.png%29%0A%0A%u5047%u8BBE%u6211%u4EEC%u8981%u5EFA%u7ACB%u4E00%u4E2A%20list%20%u7C7B%uFF0C%u5B83%u53EF%u80FD%u5305%u542B%u4E86%u4E0D%u540C%u7684%u6570%u636E%u7C7B%u578B%uFF08%u6574%u6570%uFF0C%u5E03%u5C14%uFF0Clist%u81EA%u8EAB%u7C7B%u578B%u7B49%uFF09%uFF0C%u4F8B%u5B50%u5982%u4E0B%uFF1A%0A%21%5BAlt%20text%5D%28./Selection_005.png%29%0A%0A%u8FD9%u65F6%u9700%u8981%u7528%u6CDB%u578B%u6765%u8868%u793A%u3002%u65B0%u5EFA%u4E00%u4E2Apackage%u53EBweek4%2C%u5728%u5176%u4E2D%u65B0%u5EFA%u4E00%u4E2A%20trait%u3002%u5B83%u7684%u4E24%u4E2A%u2018%u5B50%u7C7B%u2019%u5206%u522B%u4E3A%20Cons%20%u548C%20Nil%uFF0C%u5206%u522B%u8868%u793A%u542B%u6709%u5143%u7D20%u7684%u8282%u70B9%u548C%u7A7A%u8282%u70B9%u3002%0A%60%60%60scala%0Apackage%20week4%0A%0A//%20%5BT%5D%20%u662F%u7C7B%u578B%u53C2%u6570%uFF0C%u6BD4%u5982int%uFF0Cdouble%u4E4B%u7C7B%u3002%u662F%u6CDB%u578B%u7F16%u7A0B%u7684%u57FA%u7840%0Atrait%20List%5BT%5D%20%7B%0A%20%20def%20isEmpty%3A%20Boolean%0A%20%20def%20head%3A%20T%0A%20%20def%20tail%3A%20List%5BT%5D%0A%7D%0A%0Aclass%20Cons%5BT%5D%28val%20head%3A%20T%2C%20val%20tail%3A%20List%5BT%5D%29%20extends%20List%5BT%5D%20%7B%0A%20%20def%20isEmpty%20%3D%20false%0A%20%20//%20head%20%u548C%20tail%20%u5DF2%u7ECF%u5728%u521D%u59CB%u5316%u4E2D%u5B9E%u73B0%0A%7D%0A%0Aclass%20Nil%5BT%5D%20extends%20List%5BT%5D%20%7B%0A%20%20def%20isEmpty%20%3D%20true%0A%20%20def%20head%3A%20Nothing%20%3D%20throw%20new%20NoSuchElementException%28%22Nil.head%22%29%0A%20%20//%20Nothing%20%u662F%u4EFB%u4F55%u7C7B%u578B%u7684%u5B50%u7C7B%uFF0C%u6240%u4EE5%u4E5F%u662F%20T%20%u7684%u5B50%u7C7B%0A%20%20def%20tail%3A%20Nothing%20%3D%20throw%20new%20NoSuchElementException%28%22Nil.tail%22%29%0A%7D%0A%60%60%60%0A%0A%u5728%20week4%20%u4E2D%u65B0%u5EFA%u4E00%u4E2A%20scala%20worksheet%uFF0C%u6D4B%u8BD5%u4E00%u4E0B%u4E0A%u8FF0%u4EE3%u7801%uFF1A%0A%60%60%60scala%0Apackage%20week4%0A%0Aimport%20week4._%0A%0Aobject%20nth%20%7B%0A%20%20//%20%u521B%u5EFA%u4E00%u4E2A%u542B%u6709%u4E00%u4E2A%u5143%u7D20%u7684%20list%0A%20%20def%20singleton%5BT%5D%28elem%3A%20T%29%20%3D%20new%20Cons%28elem%2C%20new%20Nil%29%0A%20%20%20%20%20%20%20%20//%3E%20singleton%3A%20%5BT%5D%28elem%3A%20T%29week4.Cons%5BT%5D%0A%20%20singleton%5BInt%5D%283%29%20%20%20%20%20%20%20%20%20//%3E%20res0%3A%20week4.Cons%5BInt%5D%20%3D%20week4.Cons@71be98f5%0A%20%20singleton%283%29%20//%20%u7F16%u8BD1%u5668%u53EF%u4EE5%u4ECE%203%20%u63A8%u5230%u51FA%20T%20%u662F%20Int%20%0A%20%20%0A%20%20//%20%u5BFB%u627E%20list%20%u4E2D%u7684%u7B2C%20n%20%u4E2A%u5143%u7D20%0A%20%20def%20nth%5BT%5D%28n%3A%20Int%2C%20xs%3A%20List%5BT%5D%29%3A%20T%20%3D%0A%20%20%20%20if%20%28xs.isEmpty%29%20throw%20new%20IndexOutOfBoundsException%0A%20%20%20%20else%20if%20%28n%20%3D%3D%200%29%20xs.head%0A%20%20%20%20else%20nth%28n%20-%201%2C%20xs.tail%29%20%20%20%20%20%20%20%20//%3E%20nth%3A%20%5BT%5D%28n%3A%20Int%2C%20xs%3A%20week4.List%5BT%5D%29T%0A%20%20%20%20%0A%20%20//%20%u521B%u5EFA%u4E00%u4E2A%20list%20%20%3D%20%5B1%2C%202%2C%203%5D%0A%20%20val%20list%20%3D%20new%20Cons%281%2C%20new%20Cons%282%2C%20new%20Cons%283%2C%20new%20Nil%29%29%29%0A%20%20nth%282%2C%20list%29%20%20%20%20%20%20%20%20%20//%3E%20res2%3A%20Int%20%3D%203%0A%7D%0A%60%60%60%0A%0A---%0A%0A%23%23%23%20%u5C0F%u8BB0%0A%3E%20%u8FD9%u91CC%u662F%u8BFE%u7A0B%u524D%u56DB%u6B21%u7684%u5927%u6982%u5185%u5BB9%uFF0C%u56E0%u4E3A%u7B2C%u4E00%u6B21%u8BFE%u662F%u6559%u4F60%u600E%u4E48%u5B89%u88C5%uFF0C%u6240%u4EE5%u5B9E%u9645%u5185%u5BB9%u53EA%u6709%u4E09%u6B21%u8BFE%uFF0C%u540E%u9762%u8FD8%u6709%u4E94%u6B21%u8BFE%u3002%u603B%u4F53%u6765%u8BF4%uFF0C%u51FD%u6570%u5F0F%u7F16%u7A0B%u7ED9%u4EBA%u5F88%u591A%u542F%u53D1%uFF0C%u4F46%u662F%u5982%u679C%u4E0D%u662F%u771F%u6B63%u9700%u8981%u7528%uFF0C%u4E5F%u4E0D%u5B9C%u5360%u7528%u592A%u591A%u65F6%u95F4%u53BB%u5B66%u4E60%u3002%u6691%u5047%u8981%u53BB%u5B9E%u4E60%u4E86%uFF0C%u6CA1%u6709%u65F6%u95F4%u4E0A%u8BFE%uFF0C%u7B49%u4E0B%u5B66%u671F%u518D%u5B66%u5427%u3002%0A%0A
相關文章
相關標籤/搜索