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 ...
随机推荐
- 电脑没有关机可能出现发博文dns异常(write)
现在是把装系统的技巧基本掌握,其实弄了这么多次还是有一个突破点,就是安装系统win7选择cd的iso是要ide模式.
- 查看centos的版本
[root@NB Desktop]# lsb_release -a LSB Version: :base-4.0-amd64:base-4.0-noarch:core-4.0-amd64:core-4 ...
- 【转】JQuery插件ajaxFileUpload 异步上传文件(PHP版)
前几天想在手机端做个异步上传图片的功能,平时用的比较多的JQuery图片上传插件是Uploadify这个插件,效果很不错,但是由于手机不支持flash,所以不得不再找一个文件上传插件来用了.后来发现a ...
- 【PHP对XML文件的操作技术【完整版】】
无论是c/c++还是java.c#均有对XML文件操作的技术,PHP对XML文件的操作的技术主要有三种: DOM.XPath.SimpleXml. 一.DOM DOM:Document Object ...
- MVA Universal Windows Apps系列学习笔记1
昨天晚上看了微软的Build 2015大会第一天第一场演讲,时间还挺长,足足3个小时,不过也挺震撼的.里面提到了windows 10.Microsoft edge浏览器.Azure云平台.Office ...
- android 入门-android Studio 配置
重要:sdk 最好先有一个版本 19版本.build-tools 19.1.0 extras 19.0和platforms android-19 1.下载android sdk 和jdk 并配置环境变 ...
- 禁用编译器自动生成的函数(Effective C++之06)
如果想让你的类定义出来的对象是独一无二的,即对象无法被复制,或者使用赋值操作符赋给另外一个对象,那么最好的方法就是禁用拷贝构造函数和赋值操作符.下面介绍几种禁用的方法.(方法来自Effective C ...
- 【vijos】P1514天才的记忆
描述 从前有个人名叫W and N and B,他有着天才般的记忆力,他珍藏了许多许多的宝藏.在他离世之后留给后人一个难题(专门考验记忆力的啊!),如果谁能轻松回答出这个问题,便可以继承他的宝藏.题目 ...
- Linux学习笔记(23) Linux备份
1. 备份概述 Linux系统需要备份的数据有/root,/home,/var/spool/mail,/etc及日志等其他目录. 安装服务的数据需要备份,如apache需要备份的数据有配置文件.网页主 ...
- C# 溢出检查
checked: byte b = 255; checked { b++; } Console.WriteLine(b.ToString()); 执行出错:算术运算导致溢出. unchecked: b ...