bzoj 1098 [POI2007]办公楼biu bfs+补图+双向链表
2024-08-27 05:39:58
[POI2007]办公楼biu
Time Limit: 20 Sec Memory Limit: 162 MB
Submit: 1543 Solved: 743
[Submit][Status][Discuss]
Description
FGD开办了一家电话公司。他雇用了N个职员,给了每个职员一部手机。每个职员的手机里都存储有一些同事的
电话号码。由于FGD的公司规模不断扩大,旧的办公楼已经显得十分狭窄,FGD决定将公司迁至一些新的办公楼。FG
D希望职员被安置在尽量多的办公楼当中,这样对于每个职员来说都会有一个相对更好的工作环境。但是,为了联
系方便起见,如果两个职员被安置在两个不同的办公楼之内,他们必须拥有彼此的电话号码。
Input
第一行包含两个整数N(2<=N<=100000)和M(1<=M<=2000000)。职员被依次编号为1,2,……,N.以下M行,每
行包含两个正数A和B(1<=A<b<=n),表示职员a和b拥有彼此的电话号码),li <= 1000
Output
包含两行。第一行包含一个数S,表示FGD最多可以将职员安置进的办公楼数。第二行包含S个从小到大排列的
数,每个数后面接一个空格,表示每个办公楼里安排的职员数。
Sample Input
7 16
1 3
1 4
1 5
2 3
3 4
4 5
4 7
4 6
5 6
6 7
2 4
2 7
2 5
3 5
3 7
1 7
1 3
1 4
1 5
2 3
3 4
4 5
4 7
4 6
5 6
6 7
2 4
2 7
2 5
3 5
3 7
1 7
Sample Output
3
1 2 4
1 2 4
HINT
题解:用链表维护,能放就放,然后就好了,最后排个序。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<vector>
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int n,m,ans,cnt;
struct edge{int to,next;}e[];
int a[],q[];
int pre[],next[],last[];
int belong[];
bool vis[],t[];
void insert(int u,int v)
{
e[++cnt].to=v;e[cnt].next=last[u];last[u]=cnt;
e[++cnt].to=u;e[cnt].next=last[v];last[v]=cnt;
}
void del(int x)
{
int t=pre[x];
next[t]=next[x];
pre[next[x]]=t;
}
void bfs(int x)
{
int head=,tail=;
q[]=x;
while(head!=tail)
{
a[ans]++;
int now=q[head];head++;
for(int i=last[now];i;i=e[i].next)t[e[i].to]=;
for(int i=next[];i<=n;i=next[i])
if(!t[i])
del(i),q[tail++]=i;
for(int i=last[now];i;i=e[i].next)t[e[i].to]=;
}
}
int main()
{
n=read();m=read();
for(int i=;i<=n;i++)next[i]=i+;
for(int i=;i<=n+;i++)pre[i]=i-;
for(int i=;i<=m;i++)
{
int u=read(),v=read();
insert(u,v);
}
for(int i=next[];i<=n;i=next[])
del(i),ans++,bfs(i);
printf("%d\n",ans);
sort(a+,a+ans+);
for(int i=;i<=ans;i++)
printf("%d ",a[i]);
return ;
}
最新文章
- 获取youku视频下载链接(wireshark抓包分析)
- React.js入门笔记(续):用React的方式来思考
- Xcode 6制作动态及静态Framework
- ASP.NET MVC分页组件MvcPager 2.0版发布暨网站全新改版
- js事件委托的方式绑定详解
- checkboxes(复选按钮)
- Xcode——创建你自己的Framework
- Php面向对象 – 单例模式
- django+nginx+uwsgi 部署配置
- 转: JMeter技巧集锦
- ACCESS数据库增强器需求及介绍
- Angular4 后台管理系统搭建(1) - 建立一个通用的Wijmo5 flexgrid分页器组件
- JSR303的数据校验-Hibernate Validator方式实现
- Windows Server2012 R2 安装.NET Framework 3.5
- sql的日期和时间函数–date_format
- SpringBoot集成阿里巴巴Druid监控
- linux中VI编写C程序。。。
- DATAPUMP进程查询
- 正则表达式识别js跳转的链接
- linux shell 脚本攻略学习8---md5校验,sort排序,uniq命令详解
热门文章
- 【jmeter进阶之逻辑控制器】
- 剑指offer-从上往下打印二叉树22
- geth账户密码
- openstack对接VMware浅析
- SpringBoot日志配置(详解) 涉及控制台输出日志、生成日志文件、日志级别修改、hibernate日志不输出
- c# dll问题
- iOS-明杰解决字段冲突,及数组映射
- ManagementClass(";Win32_Share";)之共享目录
- 自学网络 arp_ignore/arp_announce
- 几种常见web 容器比较