Az algoritmus a következő három halmazzal dolgozik: 1. R – Az aktuális klikk (kezdetben üres). 2. P – Azok a csúcsok, amelyek még hozzáadhatók ( R )-hez. 3. X – Azok a csúcsok, amelyek korábban voltak ( R )-ben, de már nem lehetnek részei az aktuális klikknek.
function BronKerbosch(R, P, X): if P és X üres: output R # R egy maximális klikk for minden v ∈ P: BronKerbosch(R ∪ {v}, P ∩ N(v), X ∩ N(v)) P := P \ {v} X := X ∪ {v}
A pivotálás csökkenti az algoritmus által bejárt csúcsok számát azáltal, hogy a választott pivotcsúcs szomszédait előnyben részesíti.
function BronKerboschPivot(R, P, X): if P és X üres: output R # R egy maximális klikk pivot = egy elem P ∪ X-ből for minden v ∈ P \ N(pivot): BronKerboschPivot(R ∪ {v}, P ∩ N(v), X ∩ N(v)) P := P \ {v} X := X ∪ {v}
def bron_kerbosch(R, P, X, graph, results):
"""
Bron-Kerbosch algoritmus maximális klikkek keresésére.
Args:
R: Az aktuális klikk.
P: Azok a csúcsok, amelyek még hozzáadhatók a klikkhez.
X: Azok a csúcsok, amelyek nem bővíthetik a klikket.
graph: A gráf szomszédsági listája.
results: Az összes maximális klikket tartalmazó lista.
"""
if not P and not X:
results.append(R)
return
for v in list(P):
bron_kerbosch(R.union({v}),
P.intersection(graph),
X.intersection(graph),
graph,
results)
P.remove(v)
X.add(v)
# Példa gráf
graph = {
1: {2, 3},
2: {1, 3, 4},
3: {1, 2, 4},
4: {2, 3}
}
results =
bron_kerbosch(set(), set(graph.keys()), set(), graph, results)
print("Maximális klikkek:", results)
#include <iostream>
#include <vector>
#include <set>
#include <unordered_map>
#include <algorithm>
using namespace std;
typedef unordered_map<int, set<int>> Graph;
void bronKerbosch(set<int> R, set<int> P, set<int> X, const Graph& graph, vector<set<int>>& results) {
if (P.empty() && X.empty()) {
results.push_back(R);
return;
}
auto it = P.begin();
while (it != P.end()) {
int v = *it;
set<int> newR = R;
newR.insert(v);
set<int> newP, newX;
set_intersection(P.begin(), P.end(), graph.at(v).begin(), graph.at(v).end(),
inserter(newP, newP.begin()));
set_intersection(X.begin(), X.end(), graph.at(v).begin(), graph.at(v).end(),
inserter(newX, newX.begin()));
bronKerbosch(newR, newP, newX, graph, results);
P.erase(v);
X.insert(v);
it = P.begin();
}
}
int main() {
Graph graph = {
{1, {2, 3}},
{2, {1, 3, 4}},
{3, {1, 2, 4}},
{4, {2, 3}}
};
vector<set<int>> results;
bronKerbosch({}, {1, 2, 3, 4}, {}, graph, results);
cout << "Maximális klikkek:" << endl;
for (const auto& clique : results) {
for (int node : clique) {
cout << node << " ";
}
cout << endl;
}
return 0;
}
def bron_kerbosch_with_pivot(R, P, X, graph, results):
if not P and not X:
results.append(R)
return
# Pivot választása
pivot = next(iter(P.union(X)))
for v in P - graph:
bron_kerbosch_with_pivot(R.union({v}),
P.intersection(graph),
X.intersection(graph),
graph,
results)
P.remove(v)
X.add(v)
# Ugyanaz a gráf, mint korábban
results =
bron_kerbosch_with_pivot(set(), set(graph.keys()), set(), graph, results)
print("Maximális klikkek pivotálással:", results)
A Bron-Kerbosch algoritmus hatékony módszer a maximális klikkek meghatározására, különösen ritka gráfok esetében. Az algoritmus pivotálással tovább optimalizálható. Pythonban és C++-ban egyaránt könnyen implementálható, és számos területen alkalmazható, például szociális hálózatok és bioinformatikai hálózatok elemzésére.