首页
学习
活动
专区
圈层
工具
发布

写ML函数
EN

Stack Overflow用户
提问于 2017-11-15 03:37:17
回答 1查看 249关注 0票数 0

我对ML不熟悉,所以我会尽我最大的努力去理解。

编写一个名为alternate : 'a list -> 'a list的ML函数,该函数以两个长度相同的列表作为输入,并生成一个输出列表,其元素分别从第一和第二输入列表中交替提取。

示例

代码语言:javascript
复制
alternate ([1,3,5],[2,4,6]) = [1,2,3,4,5,6]  

这是我的作品:fun alternate ( x::xs,y::ys) = x::alternate(x,y);

EN

回答 1

Stack Overflow用户

发布于 2017-11-16 14:49:48

您将问题分为两个部分:递归案例和基本案例。(1)在递归的情况下,您解决了问题的某个单元,在这种情况下,将每个列表中的单个元素放在结果前面,然后递归地尝试以相同的方式解决其余的问题。(2)在基本情况下,列表为空,结果为空列表。

代码语言:javascript
复制
fun alternate (x::xs, y::ys) = x::y::alternate(xs, ys)
  | alternate ([], []) = []
  | alternate _ = raise Fail "xs and ys don't have the same length"

(3)由于函数只对偶数长度的输入定义良好,所以所有捕获模式_匹配包含两个元组的列表,其中一个为空,另一个为空,并引发异常。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47298934

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档