【练习】图论

F. Friendly Group

图中选择一个点-1

边两端点都选择+1

边一个端点选择-1

添加链接描述

复制代码
#include<iostream>
using namespace std;
#include<vector>
#include<cstring>
const int N=300010;
int n,m;
vector<int> G[N];
int temp1,temp2;
bool vis[N];int num[N];
void dfs(int u){
vis[u]=1;
temp1++;//点数
temp2+=G[u].size()-num[u];//边数

for(auto v:G[u]){
    if(!vis[v])num[v]++;//v的邻边中已算过的边个数
}

for(auto v:G[u]){
if(!vis[v])dfs(v);
}
}

int main(){
int T;cin>>T;
for(int tt=1;tt<=T;tt++){
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)G[i].clear();
    memset(vis,0,sizeof(vis));memset(num,0,sizeof(num));
    while(m--){
        int u,v;scanf("%d%d",&u,&v);
        G[u].push_back(v);G[v].push_back(u);
    }

   int ans=0;
    for(int i=1;i<=n;i++){
            if(!vis[i]){
            temp1=0;temp2=0;
            dfs(i);
            ans+=max(0,temp2-temp1);
            }
    }
printf("Case #%d: %d\n",tt,ans);
}


}
相关推荐
少了一只鹅1 分钟前
深入理解指针(5)
java·c语言·数据结构·算法
朱剑君32 分钟前
第三天——贪心算法——区间问题
算法·贪心算法
Mi Manchi261 小时前
力扣热题100之合并两个有序链表
算法·leetcode·链表
阿沁QWQ1 小时前
C语言中的文本读写和二进制读写接口
开发语言·c++·算法
仙人掌_lz2 小时前
深入理解深度Q网络DQN:基于python从零实现
python·算法·强化学习·dqn·rl
TsingtaoAI3 小时前
企业内训|智能调控系统算法与优化——某汽车厂商
算法·汽车·ai企业内训·自动驾驶企业内训·智驾企业培训
安特尼3 小时前
招行数字金融挑战赛数据分析赛带赛题二
python·算法·机器学习·金融·数据分析
qq_433554543 小时前
C++ string初始化、string赋值操作、string拼接操作
开发语言·c++·算法
理想奋斗中3 小时前
【LeetCode Hot100 | 每日刷题】排序数组
数据结构·算法·leetcode·快速排序
এ᭄画画的北北3 小时前
力扣-2.两数相加
算法·leetcode