在scala中是否有一个方法来获取List或Seq的(单个)头元素和列表的(集合)尾部?我知道有
def splitAt(n: Int): (List[A], List[A])
Run Code Online (Sandbox Code Playgroud)
我可以轻松地从元组的第一个列表中获取单个项目.但有没有内置的方法基本上是这样的?
def splitAtHead: (Option[A], List[A])
Run Code Online (Sandbox Code Playgroud)
就像我说的,你可以很容易地链接splitAt返回正确的签名,但我认为内置的方法可能能够保存一个中间元组.
编辑:
@ om-nom-nom的答案是正确的,但这就是为什么我不能使用他的第二个版本.
List[S](s1, s2, s3, s4).sortBy { _.f (h) } match {
case hd :: tail => recurse(tail)
}
Run Code Online (Sandbox Code Playgroud)
om-*_*nom 31
您可以使用模式匹配:
val hd::tail = List(1,2,3,4,5)
//hd: Int = 1
//tail: List[Int] = List(2, 3, 4, 5)
Run Code Online (Sandbox Code Playgroud)
或者只是.head/.tail方法:
val hd = foo.head
// hd: Int = 1
val hdOpt = foo.headOption
// hd: Option[Int] = Some(1)
val tl = foo.tail
// tl: List[Int] = List(2, 3, 4)
Run Code Online (Sandbox Code Playgroud)
该tail方法返回一个由除第一个元素(基本上是)以外的所有元素组成的集合head。
+------------------+------------------------+-------------------------------+
| Input | head | tail |
+------------------+------------------------+-------------------------------+
| List() | NoSuchElementException | UnsupportedOperationException |
| List(1) | 1 | List() |
| List(1, 2, 3, 4) | 1 | List(2, 3, 4) |
| "" | NoSuchElementException | UnsupportedOperationException |
| "A" | 'A' (char) | "" |
| "Hello" | 'H' | "ello" |
+------------------+------------------------+-------------------------------+
Run Code Online (Sandbox Code Playgroud)
请注意,这两种方法也适用于String类型。
回答@Leandro 问题:是的,我们可以这样做,如下所示:
scala> var a::b::c = List("123", "foo", 2020, "bar")
a: Any = 123
b: Any = foo
c: List[Any] = List(2020, bar)
scala> var a::b::c = List("123", "foo", "bar")
a: String = 123
b: String = foo
c: List[String] = List(bar)
scala> var a::b::c = List("123", "foo")
a: String = 123
b: String = foo
c: List[String] = List()
Run Code Online (Sandbox Code Playgroud)