Haskell 笔记 ①
①一切都是函数,包括常量、表达式,格式:名字 参数1 参数2.. =函数内容
②if语句(else绝对不可以省略)
F=if (..) then x
else y
③没有数组,只有列表[1,2,3,4,5], [‘h’,’e’]
列表有好多运算符:
“++” :同类型拼接
“ : “ :前端插入,1:2:3:4:5:[]等效于[1,2,3,4,5],后端插入请用++
“!!”: 下标索引,从0开始,[1,2,3]!!1=2
列表是可以嵌套的[[1,2],[3,4]]
列表是可以比较的[1,2,3]<[1,3]
列表有一些常用函数,注意这些混乱的名字
head []:返回首元素
last []: 返回尾元素
tail []:返回去除头元素后的列表
init []:返回去除尾元素后的列表
null []:检测是否空
reverse []:反转
take/drop 5 []:取/扔列表前5个元素
maximum/minimum []: 最值
sum/product []:和与积
elem 4 [1,4]: 是否存在,通常中缀形式,即 4 `elem` [1,4]
④列表可以自由推导,最好不要去推导浮点数(精度问题)
[1..20]就是1~20了,[‘a’..’z’]就是a~z
只要告诉步长就可以自由推导,如[1,4..11]=[1,4,7,11]
注意20~1应该这么写[20,19..1],因为默认的等差推导认为d>0
列表是惰性的。
[1,4..]尽管是无限的,但却是合法的,你可以take 5 [1,4..]取出前5项,要多少算多少,Lazy!
相关惰性函数(注意格式!!)
take 5 (cycle [1,2,3]) //生成123循环列表
take 5 (repeat 5) //生成5循环列表
⑤万能的列表表达式
还记得高中学集合时,描述型表示集合么 {x|x<10,x-(N}
看这个例子[x|x `mod` 3==1,odd x],这个就是给定一堆条件创造的列表,所有条件逗号隔开,且都是逻辑与关系,返回的不仅可以是x, x*y也行,(x,x)也行
列表表达式可以是函数(Orz)
看这个函数fuck xs=[x|x `mod` 3==1,odd x],调用时fuck [1..10]
列表表达式可以嵌套
[ [x|x<-xs]|xs<-xxs] ,当然xxs就得是嵌套列表
⑥细胞数组?元组!
(1,”hello”,”a”) ,用C语言来解释原理,就是建了个结构体。
列表套元组,元组的形式(个数&类型)必须一致,因为列表中的类型必须一致,一个元组就是一个结构体,一种限定的类型
二元组别称序对,有三个函数,fst/snd,取第一/第二元素,zip [1..20] [20..30],zip就是拉链的意思,自动从两个列表中生成[所有序对],长度由最短那个控制
⑦关于类型的那点事
检测类型表达式: “:t” , :t 4==5则输出4==5::BOOL,其中::负责指明类型
来看下一个完整优美的函数写法
add::Int->Int->Int->Int(忽略这句也没问题,但是编译器会给警告)
add x y z = m
类型声明格式: 参1,参2..返回值,中间用箭头连接,表示“函数推导”之意
常见类型:Int,Char,Bool,Float,Double,Integer(大整数,2333!),String
虚类型,:t head的返回结果是 head::[a]->a, :t fst则是fst::(a,b)->a
a,b这里都是很敷衍的,告诉编译器类型由元素决定,由于a,b不过是临时取的名字
⑧类型类(杂糅了好多东西的大类型接口)
-> (Eq a)与(Ord a)写函数类型时强制前置说明,如果函数里涉及==、/=, <、>
比如手艹一个min函数
min'::(Ord a)=>a->a->a
min' a b= if(a<b) then a
else b
->有一些功能类型类(Show类型和Read类型)
函数show:把任意类型值变成字符串,如show Ttrue=”True”
函数read: 把字符串通过类型推导还原类型,需要借助一个运算来推导类型
如,Read “[1,2]”+[3]=[1,2,3],直接写Read “[1,2]”是不对的
->有一些你看不到(Enum类型)
还记得列表[1..20]么, 这个列表就是Enum类型了,succ/pred函数查看推导的后继/前驱
->有一些专门打辅助(Bounded类型)
函数minBound::Int, maxBound::Int,检查类型的上下界
->普通类型总结一下(Num类型,Floating类型,Integer类型)
用于限定函数参数的类型
Haskell 笔记 ①的更多相关文章
- Haskell 笔记(三)类型系统
类型 (Type) Haskell的类型系统式静态类型系统,在编译的时候就知道数据类型,所以不同类型的值运算在编译的时候就会报错,比如用布尔值和整数运算,在C语言中这种运算就不会报错. Haskell ...
- Haskell 笔记(四)函数系统
函数系统 函数式编程当然少不了函数系统啦,在教程最初的时候就有一个最简单的函数,函数系统贯穿在Haskell全部,Haskell的函数有几个重要的性质. 首先声明一下函数的参数和返回值类型 然后有一个 ...
- Haskell 笔记 ③
①循环?NO!请递归思考问题! 手艹一个求列表中最大值代码,C语言中习惯性for扫一下比较出最大值.但是可以用递归! maximum'::(Ord a)=>[a]->a maximum' ...
- haskell笔记1
haskell platform下载:https://www.haskell.org/platform/ 进入haskell控制台,终端输入 $ ghci 编译文件 :l file.hs 数组操作 & ...
- Haskell 笔记 ②
①如何写一个求阶层函数? fac 0 =1 fac n=n*fac(n-1) 函数自适应匹配参数,可以把特判情况写在前面,注意按顺序匹配的,n这种万能情况写在最前面就完蛋了.同时你也注意到,函数只能一 ...
- haskell笔记2
模式匹配 # haskell_test.hs length' :: [a] -> a length' [] = 0 length' (_:x) = 1 + length' x as模式 xs@x ...
- Haskell复习笔记(一)
Haskell笔记这是第三次总结,前两次都因为各种原因丢失了,对于Haskell我算不上什么大神,只不过在大学时为了学习算法时选择了Haskell. 当时的入门书籍选择的是<Learn You ...
- haskell学习笔记_函数
一开始学习函数式编程语言就被告知函数式编程语言是一种“定义式”的语言,而不是一种命令式的语言,在学习haskell的函数语法时,此感觉更加强烈,haskell的函数定义倾向于一种类似C++里面的swi ...
- Haskell语言学习笔记(88)语言扩展(1)
ExistentialQuantification {-# LANGUAGE ExistentialQuantification #-} 存在类型专用的语言扩展 Haskell语言学习笔记(73)Ex ...
随机推荐
- Android 下拉刷新
以前旧版用的是开源的PullToRefresh第三方库,该库现在已经不再维护了: chrisbanes/Android-PullToRefreshhttps://github.com/chrisban ...
- C++ list的基本操作和使用
转自:http://blog.sina.com.cn/s/blog_6a4aa98201012fhn.html Lists将元素按顺序储存在链表中. 与 向量(vectors)相比, 它允许快速的插入 ...
- 为什么没有选择sipml5
转自:http://www.myvoipapp.com/blogs/yxh/2015/01/23/%E4%B8%BA%E4%BB%80%E4%B9%88%E6%B2%A1%E6%9C%89%E9%80 ...
- C# 对象转换为byte[] ,byte[]还原对象
/// <summary> /// 将一个object对象序列化,返回一个byte[] /// </summary> /// <param name ...
- loj 1044(dp+记忆化搜索)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26764 思路:dp[pos]表示0-pos这段字符串最少分割的回文 ...
- 两个本地(localhost)html文件之间的传值
什么是iframe? iframe 元素会创建包含另外一个文档的内联框架(即行内框架).可以理解为把iframe解释成“浏览器中的浏览器“ 在IE中: document.frames[i].docum ...
- Linux学习笔记(9)Linux常用命令之关机重启命令
(1)shutdown shutdown命令用于关机重启,其语法格式为: shutdown [选项] 时间 其中,-c选项表示取消前一个设置的shutdown命令,-h命令表示关机,-r命令表示重启 ...
- Spring中属性文件properties的读取与使用
实际项目中,通常将一些可配置的定制信息放到属性文件中(如数据库连接信息,邮件发送配置信息等),便于统一配置管理.例中将需配置的属性信息放在属性文件/WEB-INF/configInfo.propert ...
- banner无限轮播
activity_main.xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayou ...
- 【maven 报错】maven项目执行maven install时报错Error assembling WAR: webxml attribute is required (or pre-existing WEB-INF/web.xml if executing in update mode)
在使用maven新建的web项目中,执行 执行如上的这两个操作,报错: [ERROR] Failed to execute goal org.apache.maven.plugins:maven-co ...