弦图最小染色...先用MCS求出完美消除序列然后再暴力染色...

-------------------------------------------------------------------------------------

#include<bits/stdc++.h>
using namespace std;
const int maxn = 10009;
inline int read() {
char c = getchar();
int ret = 0;
for(; !isdigit(c); c = getchar());
for(; isdigit(c); c = getchar())
ret = ret * 10 + c - '0';
return ret;
}
struct edge {
int to;
edge* next;
} E[2000009], *pt = E, *head[maxn];
inline void add(int u, int v) {
pt->to = v; pt->next = head[u]; head[u] = pt++;
}
inline void addedge(int u, int v) {
add(u, v); add(v, u);
}
int N, label[maxn], seq[maxn], F[maxn], color[maxn];
bool done[maxn];
stack<int> S[maxn];
void init() {
N = read();
int m = read();
while(m--) {
int u = read() - 1, v = read() - 1;
addedge(u, v);
}
}
void MCS() {
for(int i = 0; i < N; i++) {
done[i] = false;
label[i] = 0;
S[0].push(i);
}
int best = 0;
for(int i = N; i--; ) {
for(; ;) {
while(!S[best].empty() && done[S[best].top()]) S[best].pop();
if(!S[best].empty()) break;
else best--;
}
int x = S[best].top(); S[best].pop();
done[seq[i] = x] = true;
for(edge* e = head[x]; e; e = e->next) if(!done[e->to]) {
if(++label[e->to] > best) best = label[e->to];
S[label[e->to]].push(e->to);
}
}
}
void solve() {
int ans = 0;
memset(color, 0, sizeof color);
memset(F, -1, sizeof F);
for(int i = N; i--; ) {
int x = seq[i];
for(edge* e = head[x]; e; e = e->next) 
F[color[e->to]] = x;
for(int i = 1; i <= N; i++) if(F[i] != x) {
ans = max(ans, color[x] = i);
break;
}
}
printf("%d\n", ans);
}
int main() {
init();
MCS();
solve();
return 0;
}

-------------------------------------------------------------------------------------

1006: [HNOI2008]神奇的国度

Time Limit: 20 Sec  Memory Limit: 162 MB
Submit: 2487  Solved: 1120
[Submit][Status][Discuss]

Description

K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的.为了巩固三角关系,K国禁止四边关系,五边关系等等的存在.所谓N边关系,是指N个人 A1A2...An之间仅存在N对认识关系:(A1A2)(A2A3)...(AnA1),而没有其它认识关系.比如四边关系指ABCD四个人 AB,BC,CD,DA相互认识,而AC,BD不认识.全民比赛时,为了防止做弊,规定任意一对相互认识的人不得在一队,国王相知道,最少可以分多少支队。

Input

第一行两个整数N,M。1<=N<=10000,1<=M<=1000000.表示有N个人,M对认识关系. 接下来M行每行输入一对朋友

Output

输出一个整数,最少可以分多少队

Sample Input

4 5
1 2
1 4
2 4
2 3
3 4

Sample Output

3

HINT

一种方案(1,3)(2)(4)

Source

转载于:https://www.cnblogs.com/JSZX11556/p/4842088.html

BZOJ 1006: [HNOI2008]神奇的国度( MCS )相关推荐

  1. 弦图与完美消除序列(bzoj 1006: [HNOI2008]神奇的国度)

    诱导子图:子图中任意一条边的两个端点一定也都在这个子图中 最大团:团中任意两点之间一定都有边,而包含顶点最多的团就是最大团 最小团覆盖:用最少的团覆盖图中所有的点 最大独立集:独立集中任意两点之间一定 ...

  2. bzoj 1006: [HNOI2008]神奇的国度

    这是个标准的弦图,但如果不知道弦图就惨了=_= 趁着这个机会了解了一下弦图,主要就是完美消除序列,求出了这个就可以根据序列进行贪心染色. 貌似这个序列很神,但是具体应用不了解-- 这道题为什么可以这么 ...

  3. 1006: [HNOI2008]神奇的国度

    图上的最小的染色方案: 学习了陈丹绮的论文: MCS算法 #include<cstdio> #define maxn 10005 #define maxm 2000005 using na ...

  4. 【BZOJ 1006】 [HNOI2008]神奇的国度

    1006: [HNOI2008]神奇的国度 Time Limit: 20 Sec   Memory Limit: 162 MB Submit: 2000   Solved: 897 [ Submit] ...

  5. [HNOI2008]神奇的国度

    1006: [HNOI2008]神奇的国度 Time Limit: 20 Sec  Memory Limit: 162 MB [Submit][Status][Discuss] Description ...

  6. P3196 [HNOI2008]神奇的国度(弦图的最小染色问题)

    整理的算法模板合集: ACM模板 题目传送门 K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的.为了巩固三角关系,K国 ...

  7. BZOJ1006神奇的国度

    1006: [HNOI2008]神奇的国度 Time Limit: 20 Sec Memory Limit: 162 MB Submit: 2789 Solved: 1255 Description ...

  8. BZOJ 1005: [HNOI2008]明明的烦恼

    BZOJ 1005: [HNOI2008]明明的烦恼 Description 自从明明学了树的结构,就对奇怪的树产生了兴趣......给出标号为1到N的点,以及某些点最终的度数,允许在 任意两点间连线 ...

  9. BZOJ 1006 神奇的国度(弦图的染色数)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1006 题意:给定一个弦图,求最小染色数.就是用最小数目的颜色进行染色使得任意两个相邻的节 ...

最新文章

  1. 设置JFrame背景图片
  2. 电脑磁盘空间不足怎么办_IT干货 丨 电脑C盘存储空间不足怎么办?
  3. Glow-流生成模型(一)
  4. 重装win7后修改桌面路径到D盘
  5. windows平台下用CMake工具编译osg用法说明
  6. 流程控制语句(bash)
  7. 【计算机组成原理】指令执行过程
  8. 【struts框架】第一节Action-struts基础
  9. NVIDIA ECCV18论文:超像素采样网络助力语义分割与光流估计(代码将开源)
  10. 架构系列---发号器(全局唯一ID生成器)系统设计方案和思路
  11. 计算机图形学设计线宽代码,计算机图形学画圆并改变线宽.pdf
  12. MATLAB强化学习实战(十) 多智能体的路径跟随控制
  13. java计算矩形_用Java实现计算矩形的面积与周长
  14. VSCode更改显示语言-如更改英语为中文或者将中文改为英语
  15. 清除90天苹果充值记录_王者荣耀安卓苹果跨系统角色转移服务,限量测试收费99元...
  16. Webstorm 分屏操作
  17. python-matplotlib库绘制饼形图专题(从一般饼状图到内嵌环形图)
  18. 大明 VS 满清,明朝的十次机会
  19. h5唤起app,清除timeout
  20. Python 把几张图片拼接成一张图片,并且写上文字

热门文章

  1. mysql死锁 简单例子_写一个Mysql死锁的例子
  2. Vmware在ubuntu虚拟机上安装Vmtools
  3. linux信号(一)--unix环境高级编程读书笔记
  4. 开课吧Java课堂:特殊的字符串如何操作,字符串如何连接
  5. 家庭记事本开发进度3
  6. 这款游戏玩法是Low了点,但赚的却是实打实的EOS。
  7. 阿里情书 | 爱情是什么模样?想来想去,都是你的模样
  8. Django中间件简析
  9. Mac 上管理多个 java 版本
  10. SAP系统的模块分类