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 ...
随机推荐
- 加载gif动画的三种方式
GifView.h/** * 调用结束就开始播放动画,如果需要用户指定何时播放的话,只需要把timer的开始放到合适的位置.通过对CFDictonaryRaf 也就是gifProperties的改变, ...
- wifi基础知识整理
转自 :http://blog.chinaunix.net/uid-9525959-id-3326047.html WIFI基本知识整理 这里对wifi的802.11协议中比较常见的知识做一个基本的总 ...
- log4j设置日志格式为UTF-8
想要log4j输出的日志文件的编码格式为UTF-8.正常情况下只需要添加下述的代码即可: log4j.appender.appender_name.Encoding=UTF-8 但是在spring与l ...
- Grafana 安装
由于 Grafana 是存静态的,你只需要下载源代码解压,将它部署在 Nginx 上面就可以了,或者可以用 Python 的 SimpleHTTPServer 来跑 $ wget http://gra ...
- jqueryEasyUI:tabs扩展:给tabs组件绑定双击事件 分类: JqueryEasyUI 2014-09-29 14:36 537人阅读 评论(0) 收藏
实现代码: $.extend($.fn.tabs.methods, { /** * 绑定双击事件 * @param {Object} jq * @param {Object} caller 绑定的事件 ...
- 智能车学习(三)—— ADC学习
一.代码分享: 1.ADC头文件 #ifndef ADC_H_ #define ADC_H_ #include "common.h" typedef enum { // ----- ...
- JSTL标签详解以及应用实例
JSTL Apache提供的标签库,jar包:jstl-1.2.jar,如果用MyEclipse,它会自动导入,无需自己导入,如果没有使用MyEclipse那么需要自行导入. ------------ ...
- 【jQuery 分页】jQuery分页功能的实现
自写的jQuery实现分页功能的分页组件: 功能效果如下: 分页组件就是上图中的三部分, 分别放在表格上部 和下部 . 其中, 1>>>页面的代码如下: product.jsp 其 ...
- Laravel系列 目录结构
Where Is The Models Directory? app directory by default 其中 app:,core code of your application, almos ...
- c#写windows服务(转)
序言 前段时间做一个数据迁移项目,刚开始用B/S架构做的项目,但B/S要寄存在IIs中,而IIs又不稳定因素,如果重启IIs就要打开页面才能运行项目.有不便之处,就改用Windows服务实现.这篇就总 ...