由于到达关系具有传递性,可以考虑不断将若干个可以相互到达的点缩点,并且当两个点只能单向到达时,能到达另一个点的点一定不是最小值

由此,我们来考虑dfs,即不断从一个节点开始,遍历其可以到达的点,当发现了环即将这些点合并(启发式合并),当发现了已经完全搜过(不在栈中)的点即一定不能作为最小值

在实现上,有一些困难,注意以下细节:

1.对每一个点还要维护一个钥匙集合,也参与启发式合并

2.启发式合并时可能有新的边可以到达,在加入时判定即可

3.由于要弹出元素,且不像强连通分量一样保证必然弹出,因此建议手动模拟栈来实现

4.在搜过一条边后将其弹出边集,以避免合并后被其他点重复搜索

5.判定是否遍历到只能单向到达的点,可以在搜索结束后再判定

  1 #include<bits/stdc++.h>
2 #include"keys.h"
3 using namespace std;
4 #define N 300005
5 #define vi vector<int>
6 #define fi first
7 #define se second
8 stack<int>st;
9 set<int>key[N];
10 set<int>::iterator it1;
11 vector<int>ans,G0[N];
12 set<pair<int,int> >G1[N];
13 set<pair<int,int> >::iterator it2;
14 int n,m,mn,dfn[N],vis[N],f[N],sz[N];
15 int find(int k){
16 if (k==f[k])return k;
17 return f[k]=find(f[k]);
18 }
19 int get_sum(int k){
20 return key[k].size()+G0[k].size()+G1[k].size();
21 }
22 void add(int x,int y,int z){
23 x=find(x);
24 if (key[x].find(z)!=key[x].end())G0[x].push_back(y);
25 else G1[x].insert(make_pair(z,y));
26 }
27 void merge(int x,int y){
28 x=find(x),y=find(y);
29 if (x==y)return;
30 if (get_sum(x)<get_sum(y))swap(x,y);
31 f[y]=x;
32 sz[x]+=sz[y];
33 for(it1=key[y].begin();it1!=key[y].end();it1++){
34 int k=(*it1);
35 key[x].insert(k);
36 while (1){
37 it2=G1[x].lower_bound(make_pair(k,0));
38 if ((it2==G1[x].end())||((*it2).fi!=k))break;
39 G0[x].push_back((*it2).se);
40 G1[x].erase(it2);
41 }
42 }
43 key[y].clear();
44 for(int i=0;i<G0[y].size();i++)G0[x].push_back(G0[y][i]);
45 G0[y].clear();
46 for(it2=G1[y].begin();it2!=G1[y].end();it2++)add(x,(*it2).se,(*it2).fi);
47 G1[y].clear();
48 }
49 void dfs(int k){
50 st.push(k);
51 while (!st.empty()){
52 k=st.top();
53 dfn[k]=1;
54 if (G0[k].empty()){
55 vis[k]=1;
56 st.pop();
57 continue;
58 }
59 int x=find(G0[k].back());
60 G0[k].pop_back();
61 if (!dfn[x]){
62 st.push(x);
63 continue;
64 }
65 if (vis[x])continue;
66 while (st.top()!=x){
67 merge(st.top(),k);
68 st.pop();
69 }
70 merge(st.top(),k);
71 st.pop();
72 st.push(find(k));
73 }
74 }
75 void check(int x,int y,int z){
76 x=find(x),y=find(y);
77 if (x!=y){
78 if (key[x].find(z)!=key[x].end())vis[x]=1;
79 if (key[y].find(z)!=key[y].end())vis[y]=1;
80 }
81 }
82 vi find_reachable(vi r,vi u,vi v,vi c){
83 n=r.size(),m=u.size();
84 for(int i=1;i<=n;i++){
85 f[i]=i,sz[i]=1;
86 key[i].insert(r[i-1]);
87 }
88 for(int i=0;i<m;i++){
89 u[i]++,v[i]++;
90 add(u[i],v[i],c[i]);
91 add(v[i],u[i],c[i]);
92 }
93 for(int i=1;i<=n;i++)
94 if (!dfn[i])dfs(i);
95 memset(vis,0,sizeof(vis));
96 for(int i=0;i<m;i++)check(u[i],v[i],c[i]);
97 mn=0x3f3f3f3f;
98 for(int i=1;i<=n;i++)
99 if (!vis[find(i)])mn=min(mn,sz[find(i)]);
100 for(int i=1;i<=n;i++)
101 if ((!vis[find(i)])&&(sz[find(i)]==mn))ans.push_back(1);
102 else ans.push_back(0);
103 return ans;
104 }

[loj3524]钥匙的更多相关文章

  1. DAY6 使用ping钥匙临时开启SSH:22端口,实现远程安全SSH登录管理就这么简单

    设置防火墙策略时,关于SSH:22访问权限,我们常常会设置服务器只接受某个固定IP(如公司IP)访问,但是当我们出差或在家情况需要登录服务器怎么办呢? 常用两种解决方案:1.通过VPN操作登录主机: ...

  2. wifi万能钥匙自媒体平台开放注册(付注册流程)

    12月13日,有网友爆料,wifi万能钥匙自媒体开放注册,看来自媒体还没有达到饱和阶段,也印证了自媒体时代才刚刚到来.现在这个自媒体的时代,几乎大多互联网企业都开通了自己的自媒体,比较知名的像今日头条 ...

  3. 使用ping钥匙临时开启SSH:22端口,实现远程安全SSH登录管理就这么简单

    设置防火墙策略时,关于SSH:22访问权限,我们常常会设置服务器只接受某个固定IP(如公司IP)访问,但是当我们出差或在家情况需要登录服务器怎么办呢? 常用两种解决方案:1.通过VPN操作登录主机: ...

  4. 使用HackRF+GNU Radio 破解吉普车钥匙信号

    引文 我最近对软件定义的无线电技术(SDR)产生了浓厚的兴趣,而我对其中一款流行的SDR平台(HackRF)也产生了兴趣,而其频率接收的范围也在1MHz ~6GHz之间(范围较广).而这里也需要提及一 ...

  5. HDU-1438 钥匙计数之一

    http://acm.hdu.edu.cn/showproblem.php?pid=1438                                钥匙计数之一 Time Limit: 200 ...

  6. 手机NFC通信的安全车钥匙

    SmartKeys for Cyber-Cars:Secure Smartphone-based NFC-enabled Car Immobicizer 手机NFC通信的安全车钥匙 1概述 如今,智能 ...

  7. 钥匙计数之一 - HDU 1438(状态压缩打表)

    分析:首先想到每个钥匙的结尾有4种状态,不过题目还需要判断有三种不同的钥匙深度,所以每种深度结尾后有2^4种状态,0000->1111,不过题目还需需要有相邻的钥匙深度大于等于3,所以需要两种不 ...

  8. [转]使用ping钥匙临时开启SSH:22端口,实现远程安全SSH登录管理就这么简单

    原文链接:使用ping钥匙临时开启SSH:22端口,实现远程安全SSH登录管理就这么简单 这个留待后面玩一下,还是有安全隐患,非核心业务 临时用一下可以. 设置防火墙策略时,关于SSH:22访问权限, ...

  9. Wi-Fi万能钥匙:说是破解,其实有危险(转)

    Wi-Fi 万能钥匙如此危险,怎样做才能让这种可能严重侵害公众利益的 app 在中国消失? 这个“钥匙”为什么能够破解 Wi-Fi?它真的是“破解” Wi-Fi 吗?两年前我就有这个疑问了,原谅我对一 ...

随机推荐

  1. Java AES 加密小试牛刀

    目录 问题出处 解决方法 方法一 方法二 方法三 补充 总结 在java开发过程中,很多时候我们都需要加密数据,例如声音.敏感信息等.我们通常使用的是 MD5加密.SHA加密.DES 加密.AES 加 ...

  2. ansible远程运维操作

    1.command 用于查看文件内容,查看磁盘,内存,启动命令等纯命令信息 ansible portal -m command -a "cat /test1/test"2.ping ...

  3. 通过ideviceinstaller获取IOS APP bundleId

    查看ios设备udid: idevice_id -l 查看ios应用的bundleId: # 安装ideviceinstaller brew install ideviceinstaller # 查看 ...

  4. 2021.3.10--vj补题

    B - Saving the City cf--1443B Bertown is a city with nn buildings in a straight line. The city's sec ...

  5. Vuex 基础

    其他章节请看: vue 快速入门 系列 Vuex 基础 Vuex 是 Vue.js 官方的状态管理器 在vue 的基础应用(上)一文中,我们已知道父子之间通信可以使用 props 和 $emit,而非 ...

  6. Oil Deposits 新年特辑篇

    链接:E - Oil Deposits 题目: The GeoSurvComp geologic survey company is responsible for detecting undergr ...

  7. NX CAM 区域轮廓铣的切削步长

    从NX3.0到NX9.0,默认都是5%.可是实际计算的精确度是不一样的.到NX8.0上发现计算速度特别慢,后来东找西找,设置这个参数可以解决.PS:请慎用!请后后面的官方解释. 官方的解释是: &qu ...

  8. 电脑日常使用bug记录

    1.由于电脑太卡了,于是决定关一点服务,一不小心,电脑无线无法使用了.启动无线服务时提示"windows无法启动wlan autoconfig服务错误1068依赖服务" 启动 Ex ...

  9. javascript-原生-结构

    1.获取用户输入内容的方法 window.prompt("提示信息","默认值"); 获取用户输入内容(字符串类型),返回用户输入内容. 2.顺序结构:所有语句 ...

  10. HCIP-RSTP

    端口角色 根端口(RP): 非根桥收到最优的BPDU配置信息的端口为根端口,(到根桥开销最小的端口),根桥没有根端口. 指定端口(DP): 两非根交换机之间连接的两个端口必有一个为指定端口,比较两个非 ...