- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在尝试在 Bron-Kerbosch 算法的 Clojure 实现中正确有效地使用集合和 clojure.set 命名空间,但遇到了困难。
我正在尝试重构我当前的实现
(defn BK [r p x graph]
(if (and (empty? p) (empty? x))
[(set r)]
(loop [p p, x x, cliques []]
(if (empty? p)
cliques
(let [v (first p)
nv (graph v)
cliques (into cliques
(BK (into r (list v))
(filter nv p)
(filter nv x)
graph))
p (rest p)
x (into x (list v))]
(recur p x cliques))))))
进入使用clojure.set
命名空间的东西
(defn BK3 [r p x graph]
(if (and (empty? p) (empty? x))
[(set r)]
(loop [p p, x x, cliques []]
(if (empty? p)
cliques
(let [v (first p)
nv (graph v)
cliques (into cliques
(BK3 (clojure.set/union (set (list v)) r)
(clojure.set/difference p nv)
(clojure.set/difference x nv)
graph))
p (rest p)
x (clojure.set/union (set (list v)) x)]
(recur p x cliques))))))
(defn get-BK3 [graph]
(BK3 (set '()) (set (doall (range (count graph)))) (set '()) graph))
尽管当前的实现会导致 StackOverflow。这是一个简短的 SSCCE,其中包含运行评估函数所需的所有代码 http://pastebin.com/PVxJidGB .
如果我在函数中的 (if (empty? p))
之前放置 prn
表单,我可以看到集合 p
被改变一次,再也不会被改变,并且集合x
也永远不会被添加到。以下内容将被打印并重复,直到发生堆栈溢出。
finalproject.core> (get-BK3 (random-graph 10 20))
"P: " #{0 7 1 4 6 3 2 9 5 8} " X: " #{}
-----------------
"P: " #{0 7 4 6 3 2 9 8} " X: " #{}
-----------------
"P: " #{0 7 4 6 3 2 9 8} " X: " #{}
-----------------
"P: " #{0 7 4 6 3 2 9 8} " X: " #{}
-----------------
....
这一定意味着在每次递归调用 BK3
时,集合 p
都没有从中删除集合 nv
吗?尽管回顾了 clojure.set/difference
help page它应该这样做吗?我是否读错了页面或有一些拼写错误导致堆栈溢出?
这是我不明白的第一个问题。我的下一个问题是 first
和 rest
不返回集合 (#{0 1 2}
) 而是列表 ((0 1 2)
)。如果将列表传递给任何 clojure.set 函数,则会引发错误。除了返回集合的 first
和 rest
之外,还有其他选择吗?
编辑:这是来自维基百科的伪代码实现,具有正确的集合概念符号。我想我对符号的解释可能不正确?
最佳答案
正如@michat所回答的,在维基百科公式中,递归调用是使用setintersection而不是setdifference,它们是不一样的。在数学中,clojure.set/difference
的匹配函数是 set complement .
对于您关于 first
和 rest
与 set
的问题,您可以使用 first
,这将产生一个元素不是按顺序排列的下一个元素(但在算法中并不重要)和 disj
从集合中删除所选元素。
请注意,您可以通过 #{}
简化 (set '())
。
以下是 clojure.set
的工作版本,具有非常快速的测试/基准,显示了 set
版本的一些性能改进:
(require '[clojure.set :as s])
(defn BK4 [r p x graph]
(if (and (empty? p) (empty? x))
[r] ;; r is already a set
(loop [p p, x x, cliques []]
(if (empty? p)
cliques
(let [v (first p) ;; p is a set, first is not necessary the next in sequence
nv (graph v) ;; take v-th set from graph
cliques (concat cliques
(BK4 (conj r v) ;; add v to the set r
(s/intersection p nv)
(s/intersection x nv)
graph))]
(recur (disj p v) (conj x v) cliques))))))
(defn get-BK4 [graph]
(BK4 #{} (set (range (count graph))) #{} graph))
测试:
(let [graph (doall (random-graph 1000 1000))
bk (time (get-BK graph))
bk4 (time (get-BK4 graph))]
(if (= bk bk4)
(println "Seems ok")
(println "ko")))
打印(在 MBP 2.5 GHz Intel Core i7 上)
"Elapsed time: 243.533768 msecs"
"Elapsed time: 19.228952 msecs"
Seems ok
关于clojure - 在 Clojure Bron-Kerbosch 实现中正确使用集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29737830/
7.21晚上加赛 T2.七负我,做这题找到了性质发现需要求最大团,不会,爆搜,打假了,赛后改,对了,但时间复杂度大爆炸,看下发题解,有这么一句话:于是学习了一下。 Bron-kerbosch
我正在尝试编写 Bron-Kerbosch algorithm 的 C# 实现在图论中,用于查找图中最大大小的团。 理想情况下,该算法会生成一个图列表,其中每个图都代表初始输入图中的最大团。我的代码没
Bron–Kerbosch algorithm是一种列出图的所有最大派系的方法。我最近成功地实现了这个算法只是为了好玩。缺点是该算法是递归的,因此只能在小图上运行,直到堆栈溢出。 应该可以使算法完全迭
我正在尝试理解 Bron-Kerbosch 的算法(带旋转)以在无向图。我有一些问题: 选择枢轴顶点有什么标准吗?我已经看到一些实现选择具有最多邻居的顶点进行优化,而其他实现则简单地选择预期顶点中的第
我在实现 Bron-Kerbosch 算法的 C 版本时遇到了一些问题: 1- 我完全不了解该算法的工作原理。我试图在 Internet 上找到引用资料,但所有这些引用资料都很糟糕,算法示例实现糟糕透
任何人都可以告诉我,我可以在网络上的哪个位置找到有关 Bron-Kerbosch 算法的解释以查找派系或在此处解释其工作原理? 我知道它发表在“算法 457:查找无向图的所有团”一书中,但我找不到描述
我目前正在尝试在 Bron-Kerbosch 算法的 Clojure 实现中正确有效地使用集合和 clojure.set 命名空间,但遇到了困难。 我正在尝试重构我当前的实现 (defn BK [r
维基百科关于 BK clique 发现的伪代码: BronKerbosch2(R,P,X): if P and X are both empty: report R as a
我一直在练习我的 C++ 算法知识,并卡在了标准 BK 实现上。该算法输出了太多派系,我似乎不明白为什么。我将图形表示为邻接表: vector > adjacency_list; 我的 BK 函数如下
简而言之,我的原始代码(用 Ruby 编写)如下所示: # $seen is a hash to memoize previously seen sets # $sparse is a hash of
对于一个大学项目,我正在尝试实现 Bron–Kerbosch algorithm ,即列出给定图中的所有最大团。 我正在尝试实现第一个算法(不旋转),但我的代码在 Wikipedia's exampl
我正在寻找 Bron-Kerbosch algorithm 的 Javascript 实现或 Girvan-Newman algorithm . 基本上,我想在无向图中为最大集团/社区着色。 遗憾的是
我一直在尝试实现 Bron-Kerbosch algorithm在 Rust 中为我的硕士论文。到目前为止一切正常,但是当我尝试从 BTreeSet 更改时到 HashSet出于性能比较的目的,行为变
我是一名优秀的程序员,十分优秀!