学习了一些scala的基础语法http://twitter.github.io/scala_school/zh_cn/index.html,
尝试一下scala的函数式编程。
用函数式编程如何实现:sum(f, a,b)=
s = 0
for i in [a, b]
s+=f(i)
return s
这是命令式编程,c/c++的伪代码。
1. 实现1.
1 def sum(f:Int=>Int, a:Int, b:Int):Int = { 2 if(a > b) 0 else f(a) + sum(a+1, b) 3 }
sum(x=>x, 1, 5)
sum(x=>x*x*x, 1, 5)
2. 实现2
这里有三个参数,f, a, b.是否可以将sum抽象成一个输入是f,输出是g: (Int, Int)=>Int的函数呢?然后用生成的g作用到a, b上?
1 def sum(f:Int=>Int):(Int, Int)=>Int = { 2 def func(a:Int, b:Int):Int = { 3 if(a > b) 0 else f(a)+func(a+1, b) 4 }
5 func 6 }
sum(x=>x)(1,5)
sum(x=>x*x*x)(1,5)
将f抽象出来了。