gpt4 book ai didi

haskell - 如何在 Haskell 中模拟指针?

转载 作者:行者123 更新时间:2023-12-04 03:39:30 26 4
gpt4 key购买 nike

我正在尝试在 Haskell 中实现 Dijkstra 的算法。我已经使用树实现了一个二叉堆。在算法中,当前顶点的邻居键应该在堆中更新。如何在 Haskell 中模拟指向堆中值的指针?如何在每次操作后堆都发生变化时快速访问堆中的元素?

最佳答案

查看包裹Data.IORefData.STRef这使您可以访问可变引用。如果您还需要执行 IO,请使用 IORefs,如果不需要,请使用 STRefs。

但是,我怀疑您可能做错了。完全可以在没有可变状态的情况下实现 Dijkstra 算法(尽管您需要小心一点,因为如果您不断地重新计算可以缓存的函数评估,您很容易导致渐近运行时间爆炸)。

关于haskell - 如何在 Haskell 中模拟指针?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11222991/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com