首页 > 其他 > 详细

Haskell 笔记 ③

时间:2015-02-08 00:22:51      阅读:290      评论:0      收藏:0      [点我收藏+]

①循环?NO!请递归思考问题!

手艹一个求列表中最大值代码,C语言中习惯性for扫一下比较出最大值。但是可以用递归!

maximum::(Ord a)=>[a]->a

maximum []=error "empty!"

maximum [x]=x

maximum (x:xs) = max x (maximum xs) 

同样的对列表的递归技巧可以手艹出takereverserepeatzip

rev::[a]->[a]
rev []=[]
rev (x:xs)=rev xs++[x]  //后端插入用++
zip::[a]->[b]->[(a,b)]
zip [] _=[]
zip _ []=[]
zip (x:xs) (y:ys)=[(x,y)]++zip xs ys

 

 

 

Haskell 笔记 ③

原文:http://www.cnblogs.com/neopenx/p/4279580.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!