博客
关于我
Codeforces Round #599 (Div. 1) B. 0-1 MST(图论+dfs)
阅读量:390 次
发布时间:2019-03-05

本文共 632 字,大约阅读时间需要 2 分钟。

在这里插入图片描述
在这里插入图片描述
思路:答案很容易想到就是非直连边的连通块的数量-1,这题难就难在你想到了,但你不会实现。。。
vis一开始存的是所有点,temp存的就是与当前点x的非直连点,每次dfs到一个点的时候就将与他非直连点从vis里删除。

#include
using namespace std;const int maxn = 1e5+1;set
g[maxn],vis;//vis是非直连边的集合 int n,m,v[maxn],ans;void dfs(int x){ v[x]=1; vis.erase(x); vector
temp; for(int it:vis) if(!g[it].count(x)) temp.push_back(it); for(int i:temp) vis.erase(i); for(int i:temp) dfs(i); }int main(){ scanf("%d%d",&n,&m); for(int i=1,u,v;i<=m;++i) { scanf("%d%d",&u,&v); g[u].insert(v);g[v].insert(u); } for(int i=1;i<=n;++i) vis.insert(i); for(int i=1;i<=n;++i) if(!v[i]) ans++,dfs(i); printf("%d\n",ans-1); }

转载地址:http://moewz.baihongyu.com/

你可能感兴趣的文章
NetMizer-日志管理系统 dologin.php SQL注入漏洞复现(XVE-2024-37672)
查看>>
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>
netron工具简单使用
查看>>
NetScaler MPX Gateway Configuration
查看>>
NetScaler的常用配置
查看>>
netsh advfirewall
查看>>
NETSH WINSOCK RESET这条命令的含义和作用?
查看>>
netstat kill
查看>>
netstat命令用法详解
查看>>
Netstat端口占用情况
查看>>
Netty 4的内存管理:sun.misc.Unsafe
查看>>
Netty channelRegistered\ChannelActive---源码分析
查看>>
Netty NIO transport && OIO transport
查看>>
Netty WebSocket客户端
查看>>
netty 主要组件+黏包半包+rpc框架+源码透析
查看>>
Netty 异步任务调度与异步线程池
查看>>
Netty 解决TCP粘包/半包使用
查看>>
netty——Future和Promise的使用 线程间的通信
查看>>
netty——黏包半包的解决方案、滑动窗口的概念
查看>>
Netty中使用WebSocket实现服务端与客户端的长连接通信发送消息
查看>>