P1262 间谍网络
思路:
①在 Tarjan 的基础上加一个 belong 记录每个点属于哪个强连通分量。
②存图完成后,暴力地遍历全图,查找是否要间谍不愿受贿。
inline void dfs(int u)
{
if(vis[u]) return ;
vis[u]=true,tot++;
for(int i=head[u];i;i=t[i].nex)
dfs(t[i].to);
}//遍历
遍历完后,看看那个间谍没被搜索过(vis数组记录),就把那个不受贿的间谍抓出来。
③如果所有的间谍都愿意受贿,就继续。可以开一个smon数组,记录每个强连通分量中间谍愿意受贿的最小的钱数。结合belong数组(因为一个强连通分量只要让一个间谍受贿,就能拖出这个强连通分量中所有的间谍。),用ans记录所需总的钱数,输出。
AC代码:
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<string>
#include<algorithm>
#include<queue>
#include<stack>
#include<deque>
using namespace std;
#define maxn 3001
#define maxm 9000000
#define INF 0x3f3f3f3f
int n,m,cnt,tot,dfn[maxn],low[maxn],sta[maxn],belong[maxn],rd[maxn],smon[maxn],mon[maxn];
//belong记录每个点属于哪个强连通分量,rd记录每个点的入度,smon记录间谍网络中每个连通块的最小受贿的钱,mon记录每个间谍的受贿所需的钱
bool vis[maxn];
struct hh
{
int nex,to;
}t[maxm];
int tto=,head[maxm];//链式前向星
inline void add(int nex,int to)
{
t[++tto].nex=head[nex];
t[tto].to=to;
head[nex]=tto;
}//存图部分
inline void dfs(int u)
{
if(vis[u]) return ;
vis[u]=true,tot++;
for(int i=head[u];i;i=t[i].nex)
dfs(t[i].to);
}//遍历初始图
inline int read()
{
char kr=;
char ls;
for(;ls>''||ls<'';kr=ls,ls=getchar());
int xs=;
for(;ls>=''&&ls<='';ls=getchar())
{
xs=xs*+ls-;
}
if(kr=='-') xs=-xs;
return xs;
}//快读
inline void tarjan(int u)//tarjan的模板
{
dfn[u]=low[u]=++tot;
vis[u]=true;
sta[++cnt]=u;
for(int i=head[u];i;i=t[i].nex)
{
int v=t[i].to;
if(!dfn[v])
{
tarjan(v);
low[u]=min(low[u],low[v]);
}
else if(vis[v])
{
low[u]=min(low[u],dfn[v]);
}
}//日常操作
if(dfn[u]==low[u])
{
smon[u]=INF;
do
{
vis[sta[cnt]]=false;
belong[sta[cnt]]=u;
smon[u]=min(smon[u],mon[sta[cnt]]);//取连通块中间谍受贿的最小值,更新smon
cnt--;
}while(sta[cnt+]!=u);
}
}
int main()
{
n=read();m=read();
for(int i=;i<=n;i++)
mon[i]=INF;//不受贿的间谍设为一个极大值
for(int i=;i<=m;i++)
{
int x,y;
x=read();y=read();
mon[x]=y;//读入受贿间谍要的钱
}
m=read();
for(int i=;i<=m;i++)
{
int x,y;
x=read();y=read();
add(x,y);//加边存图
}
for(int i=;i<=n;i++)
if(mon[i]!=INF)
dfs(i);//遍历全图,确定是否有间谍不愿被收买
for(int i=;i<=n;i++)
{
if(!vis[i])//找到那个不愿被收买的间谍
{
printf("NO\n%d",i);
return ;//直接结束程序
}
}
tot=;
for(int i=;i<=n;i++)
vis[i]=;//初始化vis
for(int i=;i<=n;i++)
if(mon[i]!=INF && !dfn[i])
tarjan(i);//tarjan记录强连通分量数,及每个强连通分量的smon
for(int i=;i<=n;i++)
{
for(int j=head[i];j;j=t[j].nex)
{
if(belong[i]!=belong[t[j].to])
rd[belong[t[j].to]]++;//统计每个强连通分量的入度 (找入度为0的点)
}
}
int ans=;
for(int i=;i<=n;i++)
if(belong[i]==i && !rd[i])
ans+=smon[i];//入度为0的点,即为连通块的起点,且smon已经被更新,直接加入答案
printf("YES\n%d",ans);//输出
return ;
}
其实也没有想象中的那么暴力,手写栈+inline后,最慢的一个点都只用了4ms。
P1262 间谍网络的更多相关文章
- Luogu P2002 消息扩散&&P1262 间谍网络
怕自己太久没写Tarjan了就会把这种神仙算法忘掉. 其实这种类型的图论题的套路还是比较简单且显然的. P2002 消息扩散 很显然的题目,因为在一个环(其实就是强连通分量)中的城市都只需要让其中一个 ...
- 洛谷——P1262 间谍网络
P1262 间谍网络 题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B间谍的犯罪证据,则称A可以揭发B.有些间谍收受贿赂,只要给他们一定数量的美元,他们就愿意 ...
- 洛谷 P1262 间谍网络==Codevs 4093 EZ的间谍网络
4093 EZ的间谍网络 时间限制: 10 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B ...
- 洛谷P1262 间谍网络[强连通分量 BFS]
题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B间谍的犯罪证据,则称A可以揭发B.有些间谍收受贿赂,只要给他们一定数量的美元,他们就愿意交出手中掌握的全部情报 ...
- 洛谷 P1262 间谍网络 Label: Kosarajn强联通
题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B间谍的犯罪证据,则称A可以揭发B.有些间谍收受贿赂,只要给他们一定数量的美元,他们就愿意交出手中掌握的全部情报 ...
- 洛谷P1262 间谍网络
本来只想刷道小题,没想到还有点麻烦 题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B间谍的犯罪证据,则称A可以揭发B.有些间谍收受贿赂,只要给他们一定数量的美 ...
- 洛谷P1262间谍网络
题目 我们首先考虑该题没有环应该怎么做,因为没有环所以是一个DAG,因此直接加上入度为0的罪犯,而有环则可以缩点,之后就成为了DAG,然后用一方法做就好了. \(Code\) #include < ...
- P1262 间谍网络 (tarjan缩点 水过去)
题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B间谍的犯罪证据,则称A可以揭发B.有些间谍收受贿赂,只要给他们一定数量的美元,他们就愿意交出手中掌握的全部情报 ...
- luogu P1262 间谍网络
嘟嘟嘟 建图还是很明显的. 接着分两种情况: 1.图中不存在环:那么只要收买那些入度为0的点.如果这些点有的不能收买.就不能控制所有间谍. 2.图中存在环,那么对于这些在环中的点,我们只要收买数额最少 ...
随机推荐
- NoSql Cassandra
我们为什么要使用NOSQL非关系数据库? 随着互联网web2.0网站的兴起,非关系型的数据库现在成了一个极其热门的新领域,非关系数据库产品的发展非常迅速.而传统的关系数据库在应付web2.0网站,特别 ...
- gulp和webpack的区别
一.概念 gulp 构建工具 我们可以通过给gulp配置不通的task(通过Gulp中的gulp.task()方法配置,比如启动server.sass/less预编译.文件的合并压缩等等)来让gulp ...
- 前端框架VUE----组件的创建
vue的核心基础就是组件的使用,玩好了组件才能将前面学的基础更好的运用起来.组件的使用更使我们的项目解耦合.更加符合vue的设计思想MVVM. 那接下来就跟我看一下如何在一个Vue实例中使用组件吧! ...
- The Little Prince-12/11
The Little Prince-12/11 最后一段话!!!hha,傻傻的我们...... 成人们对数字情有独钟.如果你为他们介绍一个朋友,他们从不会问你“他的嗓子怎么样?他爱玩什么游戏?他会采集 ...
- JQuery ajax请求返回(parsererror)异常处理
目前在学习一个Java应用的框架,反编译后在执行时一直报错,界面上显示”parsererror”,经过JavaScript调试后发现更详细的错误提示信息是 Unexpected token ' in ...
- 流媒体协议(RTMP、RTSP、UDP、HTTP、MMS)转换小工具(RTSP转成RTMP案例展示)(转)
源: 流媒体协议(RTMP.RTSP.UDP.HTTP.MMS)转换小工具(RTSP转成RTMP案例展示)
- myBatis框架之入门(一)
什么是框架 框架就是一个架子,表演节目,舞台已经搭建好,表演什么节目,看自己的需求了. 框架是一个半成品,对于Java语言来说,框架就是封装了别人的代码.在框架的基础上我们在进一步开发,拿来主义. 框 ...
- Golang并发编程进程通信channel了解及简单使用
概念及作用 channel是一个数据类型,用于实现同步,用于两个协程之间交换数据.goroutine奉行通过通信来共享内存,而不是共享内存来通信.引用类型channel是CSP模式的具体实现,用于多个 ...
- Golang命令行拷贝文件
package main import ( "fmt" "io" "os" ) func main() { list := os.Args ...
- tcpdump 抓包工具使用
1. 常用命令 监听p4p1网卡上来自 192.168.162.14 的包 tcpdump -i p4p1 src host 192.168.162.14 tcpdump -i p4p1 dst po ...