《Two Dozen Short Lessons in Haskell》(二十四)代数类型
这是《Two Dozen Short Lessons in Haskell》这本书的最后一章,第23章没有习题。
这一章里介绍了Haskell如果自定义一种类型,并且用一个双人博弈游戏为例子讲解了如何使用这些类型,里面简单介绍了Minimax算法。
至此,这本书全部学完,当然还没用Haskell写过什么大一点的程序,只是掌握了其基本概念。
1 A tree, in computer science, is an entity
a with a root and two subtrees
b with a root and a collection of subtrees, each of which is also a tree
c with a collection of subtrees, each of which has one or more roots
d described in a diagram with circles, lines, and random connections
2 A sequence, in Haskell, is an entity
a with one or more elements
b that is empty or has a first element followed by a sequence of elements
c whose elements are also sequences
d with a head and one or more tails
3 The following definition specifies
HASKELL DEFINITION • data WeekDay =
HASKELL DEFINITION • Monday | Tuesday | Wednesday | Thursday | Friday
a a type with five constructors
b a type with five explicit constructors and two implicit ones
c a tree with five roots
d a sequence with five elements
4 Given the definition in the preceding question, what is the type of the following function f?
HASKELL DEFINITION • f Tuesday = "Belgium"
a f :: WeekDay –> String
b f :: Tuesday -> "Belgium"
c f :: Day –> Country
d type of f cannot be determined
5 Types defined in Haskell scripts with the data keyword
a must begin with a capital letter
b may be imported from modules
c must be used consistently in formulas, just like intrinsic types
d all of the above
6 What kind of structure does the following type represent?
HASKELL DEFINITION • data BinaryTree = Branch BinaryTree BinaryTree | Leaf String
a a type with four constructors
b a digital structure
c a tree made up of ones and zeros
d a tree in which each root has either two subtrees or none
7 Given the preceding definition of the type BinaryTree, which of the following defines a function that computes
the total number of Branch constructors in an entity of type BinaryTree?
a branches binaryTree = 2
b branches (Branch left right) = 2
branches (Leaf x) = 0
c branches (Branch left right) = 1 + branches left + branches right
branches (Leaf x) = 0
d branches (Branch left right) = 2*branches left + 2*branches right
branches (Leaf x) = 1
8 The formula xs!!(length xs - 1)
a is recursive
b has the same type as xs
c delivers the same result as last xs
d none of the above
9 Given the definition of the function pam in the module SequenceUtilities, the formula
pam (map (+) [1 . . 5]) 10
a delivers the same result as map (1+) [1 . . 5]
b delivers the same result as pam [1 .. 5] (map (1+))
c delivers the result [11, 12, 13, 14, 15]
d all of the above
10 Given the Grid [1,3,0, 0,0,0, 0,0,2] (as in the tic-tac-toe script), what is the status of the game?
a game over, X wins
b game over, O wins
c O’s turn to play
d X’s turn to play
11 Which of the following formulas extracts the diagonal of a grid (as in the tic-tac-toe program)?
a (take 3 . map head . iterate(drop 4)) grid
b [head grid, head(drop 4 grid), head(drop 8 grid)]
c [head grid, grid!!4, last(grid)]
d all of the above
======
答案
======
1 b
数据结构中“树”的定义,一个根及多个子树
2 b
列表有可能是空的
3 a
data可以来自定义一种类型(也就是面向对象语言中的类),这里有五个构造器constructor。只是这里的构造器都没有带参数。
4 a
这个简单,定义好的类型可以像内置的Haskell类型一样来用。
5 d
类型名称必须是大写字母开头的;可以导入模块中;可以像内置的类型一样用。
6 d
就是二叉树的定义
7 c
求二叉树的分支总数。叶子节点分支为0,否则为左子树的分支数+右子树的分支数。
8 c
!!用来取出一个列表中指定位置上的元素。这里就是取最后一个元素,与last函数一样。
9 c?
还没搞明白pam的意思。
10 c
先走画X,后走的画O。该O方走棋。
130 XX.
000 …
002 ..O
11 b?
答案是b,我认为是d。感觉这些表示方法都正确,答案a中的函数写得相当牛X,不知道为什么不正确?
《Two Dozen Short Lessons in Haskell》(二十四)代数类型的更多相关文章
- 《Two Dozen Short Lessons in Haskell》(二十二)递归
<Two Dozen Short Lessons in Haskell>(Copyright © 1995, 1996, 1997 by Rex Page,有人翻译为Haskell二十四学 ...
- 《Two Dozen Short Lessons in Haskell》所有习题的索引
<Two Dozen Short Lessons in Haskell>(Copyright © 1995, 1996, 1997 by Rex Page,有人翻译为Haskell二十四学 ...
- Bootstrap<基础二十四> 缩略图
Bootstrap 缩略图.大多数站点都需要在网格中布局图像.视频.文本等.Bootstrap 通过缩略图为此提供了一种简便的方式.使用 Bootstrap 创建缩略图的步骤如下: 在图像周围添加带有 ...
- 二十四、Struts2中的UI标签
二十四.Struts2中的UI标签 Struts2中UI标签的优势: 数据回显 页面布局和排版(Freemark),struts2提供了一些常用的排版(主题:xhtml默认 simple ajax) ...
- WCF技术剖析之二十四: ServiceDebugBehavior服务行为是如何实现异常的传播的?
原文:WCF技术剖析之二十四: ServiceDebugBehavior服务行为是如何实现异常的传播的? 服务端只有抛出FaultException异常才能被正常地序列化成Fault消息,并实现向客户 ...
- VMware vSphere 服务器虚拟化之二十四 桌面虚拟化之手动池管理物理机
VMware vSphere 服务器虚拟化之二十四 桌面虚拟化之手动池管理物理机 VMwareView手动池可以管理物理计算机 说明: 环境基于实验二十三 1.准备一台Windows 7的物理计算机名 ...
- Bootstrap入门(二十四)data属性
Bootstrap入门(二十四)data属性 你可以仅仅通过 data 属性 API 就能使用所有的 Bootstrap 插件,无需写一行 JavaScript 代码.这是 Bootstrap 中的一 ...
- 3360: [Usaco2004 Jan]算二十四
3360: [Usaco2004 Jan]算二十四 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 6 Solved: 6[Submit][Statu ...
- JAVA之旅(二十四)——I/O流,字符流,FileWriter,IOException,文件续写,FileReader,小练习
JAVA之旅(二十四)--I/O流,字符流,FileWriter,IOException,文件续写,FileReader,小练习 JAVA之旅林林总总也是写了二十多篇了,我们今天终于是接触到了I/O了 ...
随机推荐
- 初级字典树查找在 Emoji、关键字检索上的运用 Part-1
系列索引 Unicode 与 Emoji 字典树 TrieTree 与性能测试 生产实践 前言 通常用户自行修改资料是很常见的需求,我们规定昵称长度在2到10之间.假设用户试图使用表情符号
- 我的小游戏上线海外AppStore完整流程心得
1,购买一台Mac或者用VMWare 安装Mac OS流程,笔者使用VMWare. 先安装Mac OS 10.13,教程,成功后不要着急安装vmtools, 首先更新系统至最新版,因为真机测试往往需要 ...
- Apache Ignite 学习笔记(三): Ignite Server和Client节点介绍
在前两篇文章中,我们把Ignite集群当做一个黑盒子,用二进制包自带的脚本启动Ignite节点后,我们用不同的客户端连接上Ignite进行操作,展示了Ignite作为一个分布式内存缓存,内存数据库的基 ...
- 深度学习目标检测综述推荐之 Xiaogang Wang ISBA 2015
一.INTRODUCTION部分 (1)先根据时间轴讲了历史 (2)常见的基础模型 (3)讲了深度学习的优势 那就是feature learning,而不用人工划分的feature engineeri ...
- 微软职位内部推荐-Senior Software Development Engineer_Commerce
微软近期Open的职位: Are you looking for a high impact project that involves processing of billions of dolla ...
- 2-Eighteenth Scrum Meeting-20151218
任务安排 成员 今日完成 明日任务 闫昊 写完学习进度记录的数据库操作 写完学习进度记录的数据库操作 唐彬 编写与服务器交互的代码 和服务器老师交流讨论区后台接口 史烨轩 获取视频url 尝试使用 ...
- 20135323符运锦----第三周:构建一个简单的Linux系统MenuOS
相关知识点 1.arch目录 占据相当庞大的空间,X86目录下代码需要重点关注. 2.init目录 内核启动的相关代码基本都在此目录下,内含MAIN.C,文件中START_KERNEL是整个LINUX ...
- 重温servlet③
请求转发 forward 仅有一个请求 至少两个servlet 前一个的响应头保留着,但是响应体不保留了. 设置响应体太大,会报错 请求包含Include 都包含,响应头和响应体都会保留着 R ...
- spring boot 添加整合ssl使得http变成https方法
1. https出现的背景:(1)都知道http传输协议是裸漏的,明文传输的,极易被黑客拦截,因此,(2)人们想出的使用加密,也就是 对称加密 例如aes,不过这个由于因为对称加密需要每个客户端和服务 ...
- Photo Cleaner -- proposed by Wei Zhang
Need想必大家都有用手机或相机记录生活的习惯吧!在旅途中,驴友们见到美丽的风景,往往激动地咔嚓一下拍张照记录下来.完事后发现角度不太好,于是又咔嚓一下……不知不觉中一下照了好多,然而真正需要的只是那 ...