Haskell 学习笔记-02:函数是第一类对象

本文介绍了Haskell语言中函数的定义与使用,探讨了函数作为第一类对象的特点,并通过具体示例展示了列表的顺序搜索及排序算法实现。

函数是第一类对象

第一 类 对象( first- class object) 指可在运行期创建, 可用作函数参数或返回 值, 可存入变量的实体。 最常见的用法就是匿名函数。

在学数学的时候,经常见到下面这些表示方法:

x=123f(x)=x2+3x12g(x,y)=xy+5x2log(y)x=123f(x)=x2+3x−12g(x,y)=xy+5x2−log(y)

等号 = 表明了两边表达式的绑定关系。在 Haskell 中,函数也是靠 = 号来定义的,上面的绑定关系可以表示如下:

    x = 123
    f x = x^2 + 3*x - 12
    g x y = x*y + 5*x^2 -log(y)

函数的参数不需要小括号,这样,x = 123,究竟是函数还是变量?在 Haskell 中已经没有区别。在 C 语言中 x 表示变量、x() 表示函数,而这是完全不同的东西。在 Haskell 中,函数、变量、常量等,在形式上不再有区别,在本质上也是相同的东西。

今天学习了列表相关知识,下面做几个相关的练习。

练习3:顺序搜索

编写一个函数,从给定的表中搜出某个项,返回其索引编号。

search x list =
    if list == [] then -1
    else if x == last list then length list - 1
    else search x (init list)

测试一下:

>> search 12 [1,2,3,4,5,12,34,56]
5

注意,if/then 在 Haskell 中是一个系统内置函数。

练习4:比较排序

这是最原始的排序算法,代码如下,尽管本人数学功底不错,函数式编程还是不习惯:

swap :: Ord(a) => [a] -> [a]
swap [] = []
swap (x:[]) = [x]
swap (x:y:list) =
    if x < y then x:swap(y:list)
    else y:swap(x:list)

sort :: Ord(a) => [a] -> [a]
sort [] = []
sort [a] = [a]
sort list =
    let
        tmp_list = swap list
    in
        sort (init tmp_list) ++ [last tmp_list]

sort 是排序函数,swap 用于把最大的一项移动到列表的最后。

let 关键词,局部变量

上面的练习。用 let 关键词定义了临时变量 tmp_list。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

许野平

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值