在纯函数式编程中,我们不修改函数的任何参数。那么,我们如何设计一个函数来添加一个元素到它的参数,一个列表呢?例如,function list add (elem, list)
。这个问题类似于这个线程:函数式编程:状态与重新分配。
我猜测的解决方案是深度复制输入列表,然后使用一些破坏性操作append
,例如操作新列表。我对吗?
附加
我从图形复制算法中复制以下代码:
// in Node
public Node deepCopy(Map<Node, Node> isomorphism) {
Node copy = isomorphism.get(this);
if (copy == null) {
copy = new Node();
isomorphism.put(this, copy);
for (Node connection: connections) {
copy.connections.add(connection.deepCopy(isomorphism));
}
}
return copy;
}
要对图进行深度复制,必须跟踪正在复制的每个节点。在宇宙中,我们使用isomorphism
论据来做到这一点。我认为制作此deepCopy
操作的纯函数版本的唯一方法是不仅返回变量copy
,还返回一个标志,指示返回的节点是否为新节点。正确的?