- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习 Haskell,正在阅读 Tying the Knot关于如何构建循环链表。在代码中
data DList a = DLNode (DList a) a (DList a)
mkDList :: [a] -> DList a
mkDList [] = error "must have at least one element"
mkDList xs = let (first,last) = go last xs first
in first
where go :: DList a -> [a] -> DList a -> (DList a, DList a)
go prev [] next = (next,prev)
go prev (x:xs) next = let this = DLNode prev x rest
(rest,last) = go this xs next
in (this,last)
mkDList xs = let (first,last) = go last xs first
最佳答案
由于 Haskell 是惰性的,因此会评估值,直到绝对必要为止。我们可以通过一个使用等式推理的简单示例来了解我们的目标。
从最简单的例子开始:一个元素列表。
mkDList [1] == let (first, last) = go last [1] first in first
go
, 因为你不知道
last
和
first
等于还。但是,您可以将它们视为未经评估的黑匣子:它们是什么并不重要,您可以对它们进行等式推理。
-- Just plug last and first into the definition of go
-- last2 is just a renaming of the argument for clarity
go last [1] first == let this = DLNode last 1 rest
(rest, last2) = go this [] first
in (this, last2)
go
以同样的方式。
go this [] first == (first, this)
go
只是以稍微重新包装的方式评估其原始参数。
go
与它的评价。
go last [1] first == let this = DLNode last 1 rest
(rest, last2) = (first, this)
in (this, last2)
mkDList
将其代入原始方程。 :
mkDList [1] == let (first, last) = let this = DLNode last 1 rest
(rest, last2) = (first, this)
in (this, last2)
in first
mkDList
然而;我们只是使用等式推理来稍微简化它的定义。特别是,没有对
go
的递归调用。 , 只有一个
let
表达式嵌套在另一个中。
mkDlist [1]
的返回值进行模式匹配时:
let (DLNode p x n) = mkDList [1] in x
x
的值是多少?”答:我们需要对 mkDList [1]
进行模式匹配。第一的。 mkDList
的值是多少?”答:first
. first
的值是多少?”答:this
. this
的值是多少?”答:DLNode last 1 rest
x == 1
, 和
last
和
rest
不需要进一步评价。但是,您可以再次进行模式匹配以查看例如
p
的内容。是,并发现
p == last == last2 == this == DLNode last 1 rest
n == rest == first == this == DLNode last 1 rest
(first, last) = go last xs first
这样的电话它的参数实际上不需要值;它只需要占位符来跟踪什么值
first
和
last
当他们被评估时,最终会得到。这些占位符称为“thunk”,它们代表未评估的代码片段。他们让我们引用尚未填充任何内容的框,我们可以将空框传递给
go
安全地知道有人会在其他人试图查看它们之前填充它们。 (事实上,
go
本身从不这样做;它只是不断地传递它们,直到
mkDList
之外的人试图查看它们。)
关于haskell - Haskell 中这个循环链表上的 "tying the knot"是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41509890/
假设我有一个自定义类型(我可以扩展): struct Foo { int a; string b; }; 如何使该对象的实例可分配给 std::tie ,即 std::tuple引用文
我在 SQL Server 中寻找类似的东西: SELECT TOP n WITH TIES FROM tablename 我知道 PostgreSQL 中的 LIMIT,但是否存在与上述等效的内容?
我的脚本似乎有一个小问题,我需要对脚本中较早的子例程调用“tied”,以便我可以访问与哈希绑定(bind)的对象相关的函数到。问题是,当我运行脚本时,它返回错误“无法在 cbc_encrypt_tes
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
论文网址: https://dl.acm.org/doi/10.1145/3404835.3462961 。 Arxiv: https://arxiv.org/abs/2104.08419
这是我试图解决 weekly 的挑战 #2 . 挑战很模糊,所以我决定尝试用内存来实现一个标量值。我对容器应该如何工作的理解可能有缺陷,但我真正不明白的是,为什么 say self.VAR.WHAT是
在阅读 Haskell 相关的东西时,我有时会遇到“打结”这个表达,我想我理解它的作用,但不理解它的作用。 那么,对于这个概念有什么好的、基本的、简单易懂的解释吗? 最佳答案 打结是循环数据结构问题的
如何保留哈希元素的添加顺序对于第二个VAR? (哈希值的哈希值) 例如: use Tie::IxHash; my %hash; tie %hash, "Tie::IxHash"; for my $nu
我打算编写一个简单的文本查看器,我希望它能够处理非常大的文件。我正在考虑使用 Tie::File为此,并对行进行分页。这是懒惰地加载行,还是一次加载所有行? 最佳答案 它不会加载整个文件。来自 doc
我有一个 [String: Int] 类型的字典,它的值为 let dic = [“a”:4, “b”:3, “c”:3] 我想按值和使用方法对字典进行排序 dic = dic.sorted(by:
当一个函数需要返回两个参数时,你可以使用 std::pair 编写它: std::pair f() {return std::make_pair(1,2);} 如果你想使用它,你可以这样写: int
在 c++11 中,std::tie 是否允许隐式转换? 以下代码编译并运行,但我不确定幕后到底发生了什么,或者这是否安全。 std::tuple foo() { return std::make_t
std::tie 返回一个引用元组,因此您可以执行以下操作: int foo, bar, baz; std::tie(foo, bar, baz) = std::make_tuple(1, 2, 3)
我目前正在开发一款问答游戏。我写了一个 Team 类,一个 Question 类和一个 Round 类。 这是我的团队类(我不会发布属性、构造函数和方法,因为它们与我的问题无关)。 public cl
我正在阅读 a bit about tuples . 现在我不清楚以下语法: std::tie (myint, std::ignore, mychar) = mytuple; 理解它的作用并不难,但是
是否有与 Perl 等效的 Ruby Tie::File模块? 最佳答案 没有。 读取文件并将行作为 Array 返回很容易,就像在 Perl 中一样: array = File.readlines(
我使用 std::tie 并没有考虑太多。它有效,所以我刚刚接受了这一点: auto test() { int a, b; std::tie(a, b) = std::make_tuple
tying-the-knot 策略可用于构建图,例如,使用简单的两条边图作为示例: data Node = Node Node Node -- a - b -- | | -- c - d squa
#!/usr/bin/perl use strict; use warnings; use Tie::File; use Data::Dumper; use Benchmark; my $t0 = B
我写了一个花哨的“zip 迭代器”,它已经完成了许多角色(可以用于 for_each、复制循环、容器迭代器范围构造函数等......)。 在处理所涉及的对/元组的所有模板代码下,归结为迭代器的解引用运
我是一名优秀的程序员,十分优秀!