- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在研究一个单独的函数,该函数返回一个列表,该列表在列表 l 的每个 k 元素之后插入元素 x(从
列表的末尾)。例如,单独的 (1, 0, [1,2,3,4]) 应该返回 [1,0,2,0,3,0,4]。我完成了该功能并使其工作如下:
fun separate (k: int, x: 'a, l: 'a list) : 'a list =
let
fun kinsert [] _ = []
| kinsert ls 0 = x::(kinsert ls k)
| kinsert (l::ls) i = l::(kinsert ls (i-1))
in
List.rev (kinsert (List.rev l) k)
end
最佳答案
这些或多或少是我尝试使用 foldl
编写函数时的想法。/foldr
:
foldl
/foldr
从组成最终结果的逻辑中抽象出列表递归。 foldr
使用和 kinsert
给 foldr
的函数不是递归函数:fun separate (k, x, L) =
let fun kinsert (y, ys) = ...
in foldr kinsert [] L
end
kinsert
也可能是匿名的。 kinsert
因为你需要一份 k
( i
) 您逐渐递减并重置为 k
每次达到 0 时。所以同时列表kinsert
吐出相当于折叠的累积变量,i
以大致相同的方式临时累积(偶尔重置)。 kinsert
的累积变量为 i
腾出空间:fun separate (k, x, L) =
let fun kinsert (y, (i, xs)) = ...
in foldr kinsert (?, []) L
end
'a * 'a list
,这会导致两个问题:1)我们只是真的很想积累 i
暂时的,但它是最终结果的一部分。这可以通过使用 #2 (foldr ...)
丢弃它来规避。 . 2) 如果结果现在是一个元组,我不知道该放什么作为第一个 i
代替 ?
. kinsert
是一个单独的函数声明,你可以使用模式匹配和多个函数体:fun separate (k, x, L) =
let fun kinsert (y, (0, ys)) = ...
| kinsert (y, (i, ys)) = ...
in ... foldr kinsert ... L
end
kinsert
偏离折叠以一种方式执行的递归模式:在中间模式中,当 i
匹配 0
,你没有砍掉一个元素 ls
,否则折叠会迫使您这样做。所以你的 0
shell 看起来与原来的略有不同;您可能会遇到逐一错误。 foldr
实际上首先访问列表中的最后一个元素,此时 i
将有其初始值,其中与原始 kinsert
, i
的初始值当你在第一个元素时。 foldl
或 foldr
你会遇到不同的问题:foldl
将反转您的列表,但以正确的顺序处理项目。 foldr
将保持列表顺序正确,但在 k
时会产生不同的结果不分L
的长度... foldl
并反转列表:fun separate (k, x, L) =
let fun kinsert (y, (?, ys)) = ...
| kinsert (y, (i, ys)) = ...
in rev (... foldl kinsert ... L)
end
separate (2, 0, [1,2,3,4,5])
应该给 [1,2,0,3,4,0,5]
而不是 [1,0,2,3,0,5]
. 关于sml - 使用 foldl/foldr 插入函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49163757/
在 OCaml 中,函数应用程序的评估顺序是未指定的(又名非确定性的)。 在标准机器学习中,它也是非确定性的还是确定性的?您能否提供对规范部分进行澄清的引用? 编辑:对于那些稍后来的人,我还了解到,与
我是 SML 的新手,正在使用 SMLNJ 方言。 出于某种目的,我一直在尝试将 3 类型转换为 3.0(int 到 real)。 找不到出路。我怎样才能做到这一点?如何在类型之间进行转换? 最佳答案
SML中有标准的排序函数吗?互联网上的文档太少了,我找不到任何文档。 最佳答案 SML 基础库中没有定义排序功能,但大多数实现都扩展了基础库并添加了额外的功能。 因此,MosML 具有 ArraySo
1 fun max(a,b,c) = 2 if a > b a
SML长度函数: fun length(L) = if (L=nil) then 0 else 1+length(tl(L)); 例如: length [1,2,3] = 3; len
这里的第一个问题只是想作为我做了几个查询的序言,虽然我发现了多个措辞相似的问题,但我发现没有一个问题在问或回答我的问题(据我所知)。 我正在 SML 中进行类作业,因此我将省略一些细节,以便我可以自己
我正在使用带有 SML 模式的 Emacs。有时我需要清理 SML 缓冲区。我怎样才能做到这一点。 最佳答案 新泽西标准 ML 是一种函数式编程语言,它是 ML 的变体。通常它在带有插件的 EMACS
我相信我对在 SML 中捕获异常有一些基本的误解。 我写了下面的代码: fun my_g acc p = let val r = my_g acc in ca
我目前在 SML 代码中有很多打印语句,而且我正在遍历一个非常大的树,所以打印所有打印语句需要一段时间,但现在我不想看到任何打印语句和只是想看到它尽可能快地运行。但我不想评论所有的打印,因为我以后需要
我正在使用 SML/NJ,我需要使用某个文件中的一组函数 f1.sml在另一个文件中 f2.sml . 但是,我没有运行 f2.sml直接,相反,我从其他地方导入它。 如果我使用 use f2.sml
fun p( x::xl ) = if x::xl = [] then [] else [0]; 它收到警告:匹配非详尽无遗。 x::xl => ... 我想做的是: p( [] ) = []
我有这个声明: let val x = let val x = 5 in(fn y =>(y,x+y)) end in let val y=3 and z=
有没有办法使用 SML 打印完整列表? 通常在 SML 中发生的情况是,当我有太多元素时,它会打印由“,”分隔的前几个元素,然后用 ... 省略列表的其余部分,但我想看看完整列表。有什么办法吗? va
我正在尝试读取我的输入文件的名称 argv[1] 。这是我到目前为止所做的: val args = CommandLine.arguments() ; val (x::y) = args ; val
我如何转换 array输入 list输入 sml。我已经搜索了列表和数组结构函数,但没有找到执行此操作的函数(尽管有一个数组函数列表)。 列表结构说明: http://sml-family.org/B
我目前正在为 SML 类(class)的作业评分。我编写了一些测试用例来自动检查学生作业中函数的正确性,我希望能够导入他们的代码,然后针对该代码运行测试用例。我正在想象类似于 python 导入语义的
如何将命令行参数传递给 SML 脚本?我知道有一个 CommandLine.arguments()正确类型的函数( unit -> string list ),但像这样调用解释器: $ sml scr
假设我在 sml 中有一个非常大的列表,然后 sml 显示一些条目,然后开始显示 # 字符。 有人能告诉我如何查看整个列表吗? 最佳答案 假设这是 SML/NJ,您可以使用 printLength ,
我有以下公式 fun foo 0 = [0] | foo num = let val l = (num mod 2)::foo(num div 2) in rev l
我有一个关于我的作业的问题,问题是 有使用数据类型: datatype 'a llist = LList of 'a llist list| Elem of 'a; 嵌套列表由多态类型的元素或嵌套列表
我是一名优秀的程序员,十分优秀!