F# 计算列表中数字的总和
示例
通过递归
let rec sumTotal list =
match list with
| [] -> 0 // empty list -> return 0
| head :: tail -> head + sumTotal tail上面的例子表示:“看list,它是空返回0,否则它是一个非空列表所以它可能是?。[1],[1;2][1;2;3]等,如果list是[1]然后将其绑定变量head到1并tail以[]再执行head+sumTotaltail。
执行示例:
sumTotal [1; 2; 3] // head -> 1, tail -> [2; 3] 1 + sumTotal [2; 3] 1 + (2 + sumTotal [3]) 1 + (2 + (3 + sumTotal [])) //sumTotal[]定义为0,递归在此处停止 1 + (2 + (3 + 0))) 1 + (2 + 3) 1 + 5 6
封装上述模式的更通用方法是使用功能折叠!sumTotal变成这个:
let sumTotal list =List.fold(+) 0 list
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短