栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

c++ dfs部落卫队题解

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/649256.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号