এই নিবন্ধে, আমরা বাইনারি অনুসন্ধান ব্যবহার করে একটি প্রদত্ত গ্রাফের ন্যূনতম শীর্ষ কভার আকার খুঁজে বের করার জন্য একটি প্রোগ্রাম নিয়ে আলোচনা করব৷
ন্যূনতম শীর্ষবিন্দু কভার হল প্রদত্ত গ্রাফের শীর্ষবিন্দুগুলির একটি সেট যাতে গ্রাফের প্রতিটি প্রান্তটি সেই সেটের যেকোনো একটি শীর্ষবিন্দুর ঘটনা।
উদাহরণস্বরূপ, গ্রাফটি নিন
2 ---- 4 ---- 6 | | | | | | 3 ---- 5
এখানে, ন্যূনতম শীর্ষবিন্দুর আবরণটি 3 এবং 4 শীর্ষবিন্দুগুলিকে অন্তর্ভুক্ত করে৷ গ্রাফগুলির সমস্ত প্রান্তগুলি গ্রাফের 3 বা 4টি শীর্ষবিন্দুতে ঘটে৷
উদাহরণ
#include<bits/stdc++.h>
using namespace std;
#define max 15
//array to store graph
bool arr[max][max];
//check if minimum vertex cover exists
bool check_cover(int V, int k, int E) {
int set = (1 << k) - 1;
int limit = (1 << V);
//to mark the edges of size 'k'
bool vis[max][max];
while (set < limit) {
//resetting the vertex cover for each iteration
memset(vis, 0, sizeof vis);
int count = 0;
//checking the values which has a high value
for (int j = 1, v = 1 ; j < limit ; j = j << 1, v++) {
if (set & j) {
//marking the edges visited
for (int k = 1 ; k <= V ; k++) {
if (arr[v][k] && !vis[v][k]) {
vis[v][k] = 1;
vis[k][v] = 1;
count++;
}
}
}
}
//if all the edges are covered
if (count == E)
return true;
int c = set & -set;
int r = set + c;
set = (((r^set) >> 2) / c) | r;
}
return false;
}
//to find minimum vertex cover
int find_cover(int n, int m) {
//performing binary search
int left = 1, right = n;
while (right > left){
int mid = (left + right) >> 1;
if (check_cover(n, mid, m) == false)
left = mid + 1;
else
right = mid;
}
return left;
}
//inserting edge in the graph
void add_edge(int u, int v) {
arr[u][v] = 1;
arr[v][u] = 1;
}
int main() {
memset(arr, 0, sizeof arr);
int V = 6, E = 5;
add_edge(2, 3);
add_edge(2, 4);
add_edge(3, 5);
add_edge(4, 5);
add_edge(4, 6);
cout << "Size of Minimum Vertex Cover : " << find_cover(V, E) << endl;
return 0;
} আউটপুট
Size of Minimum Vertex Cover : 2