JavaScript和SICP

博主在闲暇时重看SICP并学习JavaScript,发现JavaScript和Scheme有诸多相似,其函数类似lambda算子。还给出了SICP中计算平方根的Newton - Raphson算法的Scheme和JavaScript版本代码,认为用JavaScript重写SICP里的程序很有趣。

这两天公司的项目告一段落,学校的作业不算太难。因此我颇有点闲暇,于是重看SICP,同时学学JavaScript(看了google suggest,google maps,还有CanyonBridgecbconnect,对JavaScript的兴趣一下浓厚起来)。 Douglas Crockford 说得不错,JavaScript的确和Scheme有很多相似之处。JavaScript的作者一定谙熟函数编程,不然JavaScript的函数是lambda算子也太过巧合了。比如SICP1.1里计算平方根的Newton-Raphson算法:

(define(sqrtx)
(define(good-enough?guess)
(<(abs(-(squareguess)x))0.001))
(define(improveguess)
(averageguess(/xguess)))
(define(sqrt-iterguess)
(if(good-enough?guess)
guess
(sqrt-iter(improveguess))))
(sqrt-iter1.0))

换成JavaScript版本近乎机械:

//Newton's method to find \sqrt{x}
function sqrt(x){
function sqrt_iter(guess){
if(good_enough(guess)){
return guess;
}

return sqrt_iter(improve(guess));
}

function improve(guess){
return average(guess, x/guess);
}

function average(x, y){
return (x + y)/2;
}

function good_enough(guess){
return Math.abs(guess * guess - x) < 0.001;
}

return sqrt_iter(1.0);
}

呵呵,看来把SICP里的程序用JavaScript重写也是件有趣的事。

呵呵,看来把SICP里的程序用JavaScript重写也是件有趣的事。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值