码迷,mamicode.com
首页 > 其他好文 > 详细

Haskell 笔记 ③

时间:2015-02-08 00:25:39      阅读:249      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!