在Swift中,您可以使用范围运算符获取一个数组,如下所示:
let list: String[] = ["first", "middle", "last"]
let cdr = list[1..list.endIndex]
assert(cdr == ["middle", "last"])
我正在尝试在递归函数中执行相同的操作,该函数采用String[]
参数,但没有运气:
func last(xs: String[]) -> String? {
switch xs {
case let (singleItemList) where singleItemList.endIndex == 1:
return singleItemList[0]
case let(multiItemList) where multiItemList.endIndex > 1:
let cdr: String[] = multiItemList[1..multiItemList.endIndex] // compilation error!
return last(cdr)
default:
return nil // empty list
}
}
last(["first", "middle", "last"])
last(["last"])
last([])
中间案例语句无法编译。它失败并出现此错误:
Playground execution failed: error: <REPL>:14:29: error: could not find an overload for 'subscript' that accepts the supplied arguments
let cdr: String[] = multiItemList[1..multiItemList.endIndex] // compilation error!
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
我做错了吗?我从let
得到的值的类型是不是String[]
?
我正在尝试从Scala中提出一个等效的递归last
方法(是的,我知道有更简单的方法可以将最后一个元素内置到Swift和Scala中):< / p>
def last[T](xs: List[T]): T = xs match {
case List() => throw new Error("last of empty list")
case List(x) => x
case y :: ys => last(ys)
}
答案 0 :(得分:6)
multiItemList[1..multiItemList.endIndex]
不是数组。您必须先将其转换为数组。将该行更改为以下内容:
let cdr: String[] = Array(multiItemList[1..multiItemList.endIndex])