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

子图:V'为V的子集 E'为E的子集

诱导子图:对于V' 只要在G中有边 那么在G'中同样应该有边

最大独立集:最大的一个点的子集使任何两个点不相邻——最大独立集数

最大团:点数最多的团——团数

最小染色:用最少的颜色给点染色使相邻点颜色不同——色数

最小团覆盖:用最少个数的团覆盖所有的点——最小团覆盖数

结论:  团数<=色数  最大独立集数<=最小团覆盖数

弦(Chord):连接环中不相邻的两个点的边

弦图:一个无向图称为弦图,当图中任意长度大于3的环都至少有一个弦

弦图的每一个诱导子图一定是弦图

弦图的判断:

ZJU1015

给定一个无向图,判定它是否为弦图

单纯点:设N(v)为与点v相邻的点的点集 一个点是单纯点当且仅当{v}+N(v)的诱导子图为一个团

引理:任何一个弦图都至少有一个单纯点  不是完全图的弦图至少有两个不相邻的单纯点

完美消除序列:

一个点的序列(每个点出现且恰好出现一次)V1,V2....Vn满足Vi在{Vi,Vi+1,Vn}的诱导子图中为一个单纯点

定理:一个无向图是弦图当且仅当它有一个完美消除序列

MCS算法O(n+m):

 #include <cstdio>
#include <cstring>
#include <queue>
#include <cstdlib>
#define N 10000 + 10
#define M 2000000 + 10 using namespace std; struct edge
{
int to, next;
}e[M];
int n, m, num, ans, maxs;
int p[N], seq[N], col[N], lab[N], flag[N];
struct node
{
int now;
node *next;
}f[N];//链表
void add(int x, int y)
{
e[++num].to = y;
e[num].next = p[x];
p[x] = num;
}
void put(int x)
{
node *po = (struct node *)malloc(sizeof(struct node));
po->next = f[lab[x]].next;
po->now = x;
f[lab[x]].next = po;
}//链表的插入
void read(int &x)
{
x = ;
char c = getchar();
while(c < '' || c > '') c = getchar();
while(c >= '' && c <= '')
{
x = (x << ) + (x << ) + c - '';
c = getchar();
}
}
void init()
{
int x, y;
read(n), read(m);
for (int i = ; i <= m; ++i)
{
read(x), read(y);
if (x == y) continue;
add(x, y);
add(y, x);
}
}
void create()
{
for (int i = ; i <= n; ++i)
f[i].next = NULL;//
for (int i = ; i <= n; ++i) put(i);
maxs = ;//初始化
for (int i = n; i; i--)//用逆序求
{
node *po = f[maxs].next;//找到当前最大
while(flag[po->now])
{
f[maxs].next = po = po->next;//及时删除没有用的点(漏掉的话会超时)
while(po == NULL)
{
maxs--;
po = f[maxs].next;
}
}
f[maxs].next = po->next;//更新
while(f[maxs].next == NULL) maxs--;
int x = po->now;
flag[x] = , seq[i] = x;
for (int j = p[x]; j; j = e[j].next)
if (!flag[e[j].to])
{
++lab[e[j].to];//加势
if (lab[e[j].to] > maxs) maxs = lab[e[j].to];
put(e[j].to);
}
}
}
void paint()
{
for (int i = ; i <= n; ++i)
flag[i] = -;
for (int i = n; i; i--)
{
int x = seq[i];
for (int j = p[x]; j; j = e[j].next)
flag[col[e[j].to]] = i;
for (int j = ; j <= n; ++j)
if (flag[j] != i)
{
col[x] = j;
break;
}
if (ans < col[x]) ans = col[x];
}
}
void deal()
{
create();
paint();
printf("%d\n", ans);
}
int main()
{
//freopen("kingdom.in", "r", stdin);
//freopen("kingdom.out", "w", stdout);
init();
deal();
return ;
}

BZOJ 1006

BZOJ 1006 完美消除序列&最大势算法&弦图的更多相关文章

  1. bzoj 1006 [HNOI2008]神奇的国度 弦图+完美消除序列+最大势算法

    [HNOI2008]神奇的国度 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 4370  Solved: 2041[Submit][Status][D ...

  2. 无向图的完美消除序列 判断弦图 ZOJ 1015 Fish net

       ZOJ1015 题意简述:给定一个无向图,判断是否存在一个长度大于3的环路,且其上没有弦(连接环上不同两点的边且不在环上). 命题等价于该图是否存在完美消除序列. 所谓完美消除序列:在 vi,v ...

  3. bzoj 1006: [HNOI2008]神奇的国度 弦图的染色问题&&弦图的完美消除序列

    1006: [HNOI2008]神奇的国度 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 1788  Solved: 775[Submit][Stat ...

  4. BZOJ 1006 [HNOI2008] 神奇的国度(简单弦图的染色)

    题目大意 K 国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即 AB 相互认识,BC 相互认识,CA 相互认识,是简洁高效的.为了巩固三角关系,K 国禁止四边关系,五边关系等 ...

  5. bzoj 4540 [HNOI 2016] 序列 - 莫队算法 - Sparse-Table - 单调栈

    题目传送门 传送点I 传送点II 题目大意 给定一个长度为$n$的序列.询问区间$[l, r]$的所有不同的子序列的最小值的和. 这里的子序列是连续的.两个子序列不同当且仅当它们的左端点或右端点不同. ...

  6. ●BZOJ 1006 [HNOI2008]神奇的国度(弦图最小染色数)○ZOJ 1015 Fishing Net

    ●赘述题目 给出一张弦图,求其最小染色数. ●题解 网上的唯一“文献”:<弦图与区间图>(cdq),可以学习学习.(有的看不懂) 摘录几个解决改题所需的知识点: ●子图和诱导子图(一定要弄 ...

  7. [BZOJ 1006] [HNOI2008] 神奇的国度 【弦图最小染色】

    题目链接: BZOJ - 1006 题目分析 这道题是一个弦图最小染色数的裸的模型. 弦图的最小染色求法,先求出弦图的完美消除序列(MCS算法),再按照完美消除序列,从后向前倒着,给每个点染能染的最小 ...

  8. 【BZOJ】1006: [HNOI2008]神奇的国度 弦图消除完美序列问题

    1006: [HNOI2008]神奇的国度 Description K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则. 他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的 ...

  9. BZOJ 1006 [HNOI2008]神奇的国度==最大势算法

    神奇的国度 K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的.为了巩固三角关系,K国禁止四边关系,五边关系等等的存在. ...

随机推荐

  1. 【Web】如何注释?

    HTML 形式:<!-- 注释内容 --> 实例: <!-- <p>这是第一段</p> --> CSS 形式:/* 注释内容 */ 实例: /* 选中i ...

  2. mapreducer计算原理

    mapreducer计算原理

  3. phpstorm设置的快捷键突然失效了,提示: IdeaVim ...

    下班后,打开PHPstorm,突然感觉不对,经常用的快捷键突然用不了. 例如按了 Ctrl+F 快捷键后,提示:  IdeaVim! Using the Ctrl+F shortcut for Vim ...

  4. linux学习命令收集

    多看看大神的博客  https://blog.csdn.net/tao934798774/article/details/79491951 ip addr   查看ip地址 ifconfig  查看i ...

  5. markdown中使用缩进

    在markdown中直接敲空格是不生效的. 使用html标签来实现 一个空格大小的表示:  两个空格的大小表示:  不换行空格:  别忘记分号 参考了大神的文章: markdown空格缩进以及HTML ...

  6. python-day6(正式学习)

    流程控制之while循环 语法 循环就是一个重复的过程,人需要重复做某项工作,那么计算机也一样.当ATM验证失败,那么计算机就会让我们再输入一次密码.这时候我们说的循环就是while循环,while循 ...

  7. iproute2使用及网络名称空间

    创建一个网络名称空间: 相当于创建一个完全隔离的新网络环境,这个环境包括一个独立的网卡空间,路由表,ARP表,ip地址表,iptables,ebtables,等等.总之,与网络有关的组件都是独立的. ...

  8. X86逆向12:内存补丁的制作

    本章我们将学习各种打补丁的方式,补丁在软件的破解过程中非常的重要,比如软件无法脱壳我们就只能通过打补丁的方式来破解程序,补丁原理就是当程序运行起来会被释放到内存并解码,然后补丁就通过地址或特征码定位到 ...

  9. CentOS 修改/etc/resolv.conf 重启network后又恢复到原来的状态?

    问题描述:CentOS 修改/etc/resolv.conf 执行service network restart后,/etc/resolv.conf又恢复到原来的状态 解决方法:/etc/resolv ...

  10. signalfx的中间件监控指标so cool

    signalfx的中间件监控指标so cool www.jianshu.com   对于我们做运维的来说,监控是最基本的东西,不过在初创公司很多计划是跟不上项目架构变化的,项目中会不断加入各种服务和组 ...