[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

Sample Output

3
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 ;
}

最新文章

  1. 获取youku视频下载链接(wireshark抓包分析)
  2. React.js入门笔记(续):用React的方式来思考
  3. Xcode 6制作动态及静态Framework
  4. ASP.NET MVC分页组件MvcPager 2.0版发布暨网站全新改版
  5. js事件委托的方式绑定详解
  6. checkboxes(复选按钮)
  7. Xcode——创建你自己的Framework
  8. Php面向对象 – 单例模式
  9. django+nginx+uwsgi 部署配置
  10. 转: JMeter技巧集锦
  11. ACCESS数据库增强器需求及介绍
  12. Angular4 后台管理系统搭建(1) - 建立一个通用的Wijmo5 flexgrid分页器组件
  13. JSR303的数据校验-Hibernate Validator方式实现
  14. Windows Server2012 R2 安装.NET Framework 3.5
  15. sql的日期和时间函数–date_format
  16. SpringBoot集成阿里巴巴Druid监控
  17. linux中VI编写C程序。。。
  18. DATAPUMP进程查询
  19. 正则表达式识别js跳转的链接
  20. linux shell 脚本攻略学习8---md5校验,sort排序,uniq命令详解

热门文章

  1. 【jmeter进阶之逻辑控制器】
  2. 剑指offer-从上往下打印二叉树22
  3. geth账户密码
  4. openstack对接VMware浅析
  5. SpringBoot日志配置(详解) 涉及控制台输出日志、生成日志文件、日志级别修改、hibernate日志不输出
  6. c# dll问题
  7. iOS-明杰解决字段冲突,及数组映射
  8. ManagementClass(&quot;Win32_Share&quot;)之共享目录
  9. 自学网络 arp_ignore/arp_announce
  10. 几种常见web 容器比较