系列文章bash
:l myfunctions
能够加载同目录的 myfunctions.hs,且能够重复执行:set prompt "ghci> "
能够改 prompt
:set prompt "λ "
能够获得 λ5 * -3
要写成 5 * (-3)
,否则报错1 + '1'
会报错,5 + 0.4
不报错,由于 5 也能够被看做 5.0succ 8
是取后继min 1 2
是取最小max 1 2
是取最大div 9 3
是除法succ 9 * 10
等价与 (succ 9) * 10
div 9 3
能够改为 9 `div` 3
doubleMe x = x + x
doubleUs x y = x * 2 + y * 2
if <condition> then <exp> else <exp>
不能省略 else'
字符,通常以 '
结尾的函数是非惰性求值版本,也叫严格求值a = 1
a = [1,2,3]
++
能够拼接两个列表,可是它会遍历第一个列表"hello"
是 ['h','e','l','l','o']
的语法糖:
能够在列表头部插入一个元素 1:[2,3]
[1,2]
是 1:2:[]
的语法糖!!
符号:[1,2,3] !! 0
值为 1,索引越界会报错[3, 2, 1] > [2, 1, 0]
值为 Truehead/tail/last/init/length/null/reverse/task 3/drop 3/maximum/minimum/sum/product求积
head []
报错4 `elem` [3,4,5]
值为 True[1..20]
生成 1 到 20 这 20 个数字组成的列表['a'..'z']
/ ['K'..'Z']
[2,4..20]
生成 [2, 4, 6, 8, 10, 12, 14, 16, 18, 20][20..1]
会获得空列表,应该写成 [20,19..1]
take 24 [13, 26..]
cycle [1, 2, 3]
会对列表进行无限循环,获得 1,2,3,1,2,3,1,2,3... 组成的列表repeat 5
会获得由 5 组成的无限列表repeat 3 10
会获得 [10,10,10][x* 2 | x <- [1.. 10]]
获得 [2, 4, 6, 8, 10, 12, 14, 16, 18, 20][x* 2 | x <- [1.. 10], x>5, filter2, filter3]
能够对 x 进行过滤[ x* y | x <-[1, 3, 5], y <- [2, 4, 6]]
获得长度为 9 的列表 [2,4,6,6,12,18,10,20,30][ x* y | x <-[1, 3, 5], y <- [2, 4, 6], x* y > 10]
获得 [12,18,20,30]length' xs = sum [1 | _ <- xs]
能够使用这个 length' 函数求列表的长度ghci> xxs = [[1, 3, 5, 2, 3, 1, 2, 4, 5],[ 1, 2, 3, 4, 5, 6, 7, 8, 9],[ 1, 2, 4, 2, 1, 6, 3, 1, 3, 2, 3, 6]]
ghci> [ [ x | x <- xs, even x ] | xs <- xxs]
[[2, 2, 4],[ 2, 4, 6, 8],[ 2, 4, 2, 6, 2, 6]]
复制代码
(1,3)
是 tuple,(1,'a', "hello")
也是 tuple[(1,2), (3,4,5)]
会报错,由于列表只能包含相同类型的东西