/**
* 常見高階函數(shù)
* fold函數(shù):累加函數(shù)帽哑,與reduce方法類似闸餐,不過可以設(shè)置初始值,
* 如果初始值可以是StringBuilder颂郎,可用來拼接字符串巧号,
* 參數(shù)acc的類型與初始值一致
*/
fun factorial2(n: Int): Int { //求階乘
if (n == 0) return 1
return (1..n).reduce { acc, i -> acc * i }
}
fun main(args: Array<String>) {
println("打印0到6的階乘")
(0..6).map(::factorial2).forEach(::println) //分別求0到6的階乘再遍歷打印
val list = listOf(1,2,3,4)
println("打印1到4的和")
println(list.fold(0, {acc, i -> acc + i })) //以0為初始值摹闽,求1到4的和
println("打印0到6求得各自階乘后的和")
//fold方法相比reduce方法類似宏邮,不過可以設(shè)置初始值
println((0..6).map(::factorial2).fold(5) { acc, i -> acc + i })
println("打印0到6求得各自階乘后拼接的字符串")
//分別求0到6的階乘再讓階乘的值之后拼接字符串再打印
println((0..6).map(::factorial2).fold(StringBuilder()) { acc, i ->
acc.append(i).append(",")
})
println("打印0到6逆序求得各自階乘后拼接的字符串")
//foldRight是fold的逆序操作
println((0..6).map(::factorial2).foldRight(StringBuilder()) { i, acc ->
acc.append(i).append(",")
})
println((1..6).joinToString(",")) //拼接字符串的另一種方法
}
運(yùn)行結(jié)果