题目大意:

有 \(n\) 名员工,一共有 \(m\) 种语言,每名员工都会其中 \(k_i\) 种语言(\(m \ge \boldsymbol{k_i \ge 0}\)),现规定两名员工可以交流的条件如下:

  1. 两名员工会一种及以上共同的语言。
  2. 有一名员工可以当这两名员工的翻译(即有一名员工会这两名员工会的语言中的各一种)。

每位员工所需要学习的语言数的和为多少。

题目分析:

我们可以对能够交流的员工建图,然后不难发现以下性质:

  1. 若 \(A\) 可以和 \(B\) 交流,则 \(B\) 也可以和 \(A\) 交流(即无向性)。
  2. 若 \(A\) 可以和 \(B\) 交流,\(B\) 可以和 \(C\) 交流,则 \(A\) 也可以和 \(C\) 交流(即传递性)。

所以,此时的问题就变成了给定一张无向图,问加几条边能够使其成为一张连通图。

可能有更好的做法,但我的做法如下:

  1. 若该点表的员工一种语言也不会,则 \(cnt\) 加一。
  2. 若该点没有被访问过,且该点表示的员工至少会一种语言,则 \(cnt\) 加一,然后以该点为起点进行 \(\operatorname{dfs}\)。
  3. 若该点被访问过,则跳过。

此时答案是 \(cnt - 1\)。

注意:若没有员工会语言,则此时的答案是 \(cnt\) 而不是 \(cnt-1\),因为每一名员工都要学一种语言才能交流。

综上,时间复杂度 \(O(n \times m)\),主要取决于建图部分的时间复杂度。

代码实现:

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define TIME_LIMIT (time_t)1e3
#define dbg(x) cerr<<#x<<": "<<x<<endl;
#define MAX_SIZE (int)2.1e4
vector <int> hashtable[MAX_SIZE];
unordered_map <int, bool> edges;
int head[MAX_SIZE];
int ver[MAX_SIZE];
int Next[MAX_SIZE];
int tot = 0;
void add(int u,int v){
ver[++tot] = v;
Next[tot] = head[u];
head[u] = tot;
}
bitset<MAX_SIZE>vis;
bitset<MAX_SIZE>pass;
void dfs(int step, int u, int fa){
assert(step<=114);
vis[u] = 1;
for(int i=head[u];i;i=Next[i]){
int v = ver[i];
if(v==fa)
continue;
if(v==u)
continue;
if(!vis[v])
dfs(step+1,v,u);
}
}
signed main() {
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
#ifdef LOCAL
#undef cout
#undef cin
ifstream cin("in.in");
ofstream cout("out.out");
assert(cin.is_open());
assert(cout.is_open());
freopen("in.in","r",stdin);
freopen("out.out","w",stdin);
time_t cs = clock();
#endif
//========================================
int n,m;
cin>>n>>m;
for(int i=1;i<=n;i++){
int k;
cin>>k;
for(int j=1;j<=k;j++){
int lang;
cin>>lang;
hashtable[lang].push_back(i);
}
}
for(int i=1;i<=m;i++){
auto &vec = hashtable[i];
if(vec.empty())
continue;
int u = vec[vec.size()-1];
pass[u] = 1;
vec.pop_back();
for(auto v:vec){
if(!edges[min(u,v)*100+max(v,u)]){
add(u,v);
add(v,u);
pass[v] = 1;
edges[min(u,v)*100+max(v,u)] = 1;
}
}
}
int cnt = 0;
for(int i=1;i<=n;i++) {
if(!vis[i]&&pass[i]){
dfs(1,i,i);
++cnt;
}
}
int nothing = 0;
for(int i=1;i<=n;i++)
if(!pass[i])
++nothing;
if(nothing==n)
cout<<nothing;
else
cout<<nothing+cnt-1;
//========================================
#ifdef LOCAL
cin.close();
cout.close();
time_t ce = clock();
cerr<< "Used Time: " << ce-cs << " ms."<<endl;
if(TIME_LIMIT<ce-cs)
cerr<< "Warning!! Time exceeded limit!!"<<endl;
#endif
return 0;
}

题解 CF277A的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. FPGA按键消抖

    简介 按键 按键是输入设备,一般来说,按键在没有按下的时候是高电平:当按键按下的时候,为低电平. 在DE2-70 User Manual中 Each switch provides a high lo ...

  2. 实现地图遮罩 leaflet

    1 前言 在地图中加载的底图是瓦片服务(固定大小的规则矩形),底图的范围很大,铺满了整个div,但是我们的感兴趣的部门可能只是其中一部分,如何在整个屏幕中突出感兴趣的部分-- 地图遮罩(遮挡图像中不感 ...

  3. [etcd]基本数据库操作

    前言 etcd数据库操作基本围绕着对键值和目录的CRUD操作,以及生命周期的管理. 之前在单节点部署了三实例集群,而etcdctl默认找的是127.0.0.1:2379,所以这里先声明一个临时全局变量 ...

  4. 红帽RHCE考题总结练习(8.0 ansible)

    本文是红帽RHCE考题的总结,个别题目写了多种步骤. 一.安装和配置ansible 题目: 按照下方所述,在控制节点 bastion.lab.example.com 上安装和配置 Ansible: 安 ...

  5. 4、Mybatis核心配置文件详解

    4.1.environments <!-- environments标签:配置多个连接数据库的环境 default属性:设置默认使用的环境的id --> <environments ...

  6. [ABC146F] Sugoroku

    2023-02-27 题目 题目传送门 翻译 翻译 难度&重要性(1~10):5 题目来源 AtCoder 题目算法 贪心 解题思路 对于第 ii 个点,只要到达 \(s_{i+1}\cdot ...

  7. 14.4K Star,一款外观漂亮、运行快速、动画细腻的开源免费UI组件库

    之前给大家推荐了很多后台模版,有读者希望推荐一些跟通用的好看组件,毕竟出了后台还有很多其他场景嘛.所以,今天继续给大家推荐一个广受好评的UI组件库:NextUI 主要特性 NextUI的主要目标是简化 ...

  8. 如何通过API接口获取淘宝的店铺所有商品详情

    在电子商务领域中,淘宝是亚洲最大的在线交易平台之一,拥有海量的商品资源和消费者.如果你是一名开发者,想要在自己的网站或者APP中嵌入淘宝商品资源,那么你就需要通过淘宝开放平台提供的API接口来获取这些 ...

  9. 前瞻|Java 21 新特性 String Templates(字符串模版)

    在日常写Java的时候,对于字符串的操作是非常普遍的,其中最常见的就是对字符串的组织.也因为这个操作非常普遍,所以诞生了很多方案,总下来大概有这么几种: 使用+拼接 使用StringBuffer和Sp ...

  10. 【项目源码】基于JavaEE的健康管理系统

    随着网络技术的不断发展,网站的开发与运用变得更加广泛.这次采用java语言SSH框架(Spring,Struts,Hibernate)设计并实现了面向特定群体的健康管理平台.该网站主要有教师饮食管理. ...