c++ dfs部落卫队题解

1,题目:

c++ dfs部落卫队题解_第1张图片

 2主要思路:

将m对仇敌关系转化成一张二维关系表(cd[i][j])通过调用表来减少dfs时的时间复杂度。

3代码:

#include 
#include
#include 
using namespace std;
int n,m;
int cd[105][105]={0},rs2[105]={0},rs3[105]={0},max1=0; 
void dfs(int sum,int r){
    if(r>n){
        if(sum>max1){
            max1=sum;
            for(int i=1;i<=n;i++){
                rs3[i]=rs2[i];//将选取的人录入 
            }
        }
        return ;
    }
    int check=1;//定义一个状态参量 
        for(int j=1;j>n>>m;
    for(int i=1;i<=m;i++){
        cin>>x>>y;//将仇敌对输入并储存在cd表中 
        cd[x][y]=1;//有仇敌关系则设为1,否则为零 
        cd[y][x]=1;
    }
    dfs(0,1);
    cout<

4测试数据:

7 10
1 2
1 4
2 4
2 3
2 5
2 6
3 5
3 6
4 5
5 6

3
1 0 1 0 0 0 1

你可能感兴趣的:(c++ dfs部落卫队题解)