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

题目链接: BZOJ - 1006

题目分析

这道题是一个弦图最小染色数的裸的模型。

弦图的最小染色求法,先求出弦图的完美消除序列(MCS算法),再按照完美消除序列,从后向前倒着,给每个点染能染的最小颜色。

求出的颜色数就是最小染色,同时也是最大团。

代码

#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <algorithm>
#include <queue>

using namespace std;

const int MaxN = 10000 + 5, MaxM = 1000000 + 5;

int n, m, Ans;
int V[MaxN], A[MaxN], Col[MaxN], Used[MaxN];

bool Visit[MaxN];

struct Edge
{
	int v;
	Edge *Next;
} E[MaxM * 2], *P = E, *Point[MaxN];

inline void AddEdge(int x, int y)
{
	++P; P -> v = y;
	P -> Next = Point[x]; Point[x] = P;
}

struct ES
{
	int p, q;
	ES() {}
	ES(int a, int b)
	{
		p = a; q = b;
	}
};

struct Cmp
{
	bool operator () (ES e1, ES e2)
	{
		return e1.q < e2.q;
	}
};

priority_queue<ES, vector<ES>, Cmp> Q;

//MCS 求完美消除序列
void MCS()
{
	for (int i = 1; i <= n; ++i)
	{
		V[i] = 0;
		Visit[i] = false;
	}
	while (!Q.empty()) Q.pop();
	Q.push(ES(1, 0));
	int x, y;
	for (int i = n; i >= 1; --i)
	{
		while (true)
		{
			x = Q.top().p; Q.pop();
			if (!Visit[x]) break;
		}
		A[i] = x;
		Visit[x] = true;
		for (Edge *j = Point[x]; j; j = j -> Next)
		{
			y = j -> v;
			if (Visit[y]) continue;
			++V[y];
			Q.push(ES(y, V[y]));
		}
	}
}

void Min_Paint()
{
	Ans = 1;
	int x;
	memset(Col, 0, sizeof(Col));
	memset(Used, 0, sizeof(Used));
	for (int i = n; i >= 1; --i)
	{
		for (Edge *j = Point[A[i]]; j; j = j -> Next)
			Used[Col[j -> v]] = i;
		x = 1;
		while (Used[x] == i)
		{
			++x;
			if (x > Ans) Ans = x;
		}
		Col[A[i]] = x;
	}
}

int main()
{
	scanf("%d%d", &n, &m);
	int a, b;
	for (int i = 1; i <= m; ++i)
	{
		scanf("%d%d", &a, &b);
		AddEdge(a, b);
		AddEdge(b, a);
	}
	MCS();
	Min_Paint();
	printf("%d\n", Ans);
	return 0;
}

  

时间: 2024-10-20 12:56:28

[BZOJ 1006] [HNOI2008] 神奇的国度 【弦图最小染色】的相关文章

BZOJ 1006 HNOI2008 神奇的国度 弦图最小染色 MCS算法

题目大意:给定一个弦图,求最小染色 弦图相关问题,具体见陈丹琦09年讲稿<弦图与区间图> PPT里有一个问题没说清楚 就是MCS算法的O(m+n)怎么来的 那个在 http://tieba.baidu.com/p/2891159900 有jcvb神犇详细的解答 至于染色如何标号,时间戳标记暴力硬扫即可 #include<cstdio> #include<cstring> #include<iostream> #include<algorithm>

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

1006: [HNOI2008]神奇的国度 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 1788  Solved: 775[Submit][Status] Description K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的.为了巩固三角关系,K国禁止四边关系,五边关系等等的存在.所谓N边关系,是指N个人 A1A2...An之间仅存在N对认识关系:(A1A2)

BZOJ 1006 HNOI2008 奇妙的国度 弦图最小染色 MCS算法

题目大意:给定一个弦图,求最小染色 弦图相关问题,详细见陈丹琦09年讲稿<弦图与区间图> PPT里有一个问题没说清楚 就是MCS算法的O(m+n)怎么来的 那个在 http://tieba.baidu.com/p/2891159900 有jcvb神犇具体的解答 至于染色怎样标号,时间戳标记暴力硬扫就可以 #include<cstdio> #include<cstring> #include<iostream> #include<algorithm>

bzoj 1006: [HNOI2008]神奇的国度 -- 弦图(最大势算法)

1006: [HNOI2008]神奇的国度 Time Limit: 20 Sec  Memory Limit: 162 MB Description K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的.为了巩固三角关系,K国禁止四边关系,五边关系等等的存在.所谓N边关系,是指N个人 A1A2...An之间仅存在N对认识关系:(A1A2)(A2A3)...(AnA1),而没有其它认识关系.比如四边关系指ABCD四个人

BZOJ 1006: [HNOI2008]神奇的国度 弦图的最小染色问题

弦图的最小染色问题: 先求出完美消除序列,然后从后往前贪心染色 1006: [HNOI2008]神奇的国度 Time Limit: 20 Sec  Memory Limit: 162 MB Submit: 2245  Solved: 1006 [Submit][Status][Discuss] Description K国是一个热衷三角形的国度,连人的交往也只喜欢三角原则.他们认为三角关系:即AB相互认识,BC相互认识,CA相互认识,是简洁高效的.为了巩固三角关系,K国禁止四边关系,五边关系等等

BZOJ 1006: [HNOI2008]神奇的国度( MCS )

弦图最小染色...先用MCS求出完美消除序列然后再暴力染色... ------------------------------------------------------------------------------------- #include<bits/stdc++.h> using namespace std; const int maxn = 10009; inline int read() { char c = getchar(); int ret = 0; for(; !i

BZOJ 1006 [HNOI2008]神奇的国度

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

BZOJ 1006: [HNOI2008]神奇的国度(弦图染色)

http://www.lydsy.com/JudgeOnline/problem.php?id=1006 题意: 思路: 这个就是弦图染色问题,弦图啥的反正我也不懂,具体看论文https://wenku.baidu.com/view/07f4be196c175f0e7cd13784.html 这里的话就是用最大势算法求了一个完美消除序列,然后根据完美消除序列来进行染色即可. 1 #include<iostream> 2 #include<algorithm> 3 #include&

bzoj 1006: [HNOI2008]神奇的国度【弦图+LesBFS】

参考论文:https://wenku.baidu.com/view/6f9f2223dd36a32d73758126.html 参考代码:http://hzwer.com/3500.html 虽然会写了但是我还是不知道弦图是个什么玩意 #include<iostream> #include<cstdio> using namespace std; const int N=20005,M=2000005; int n,m,h[N],cnt,d[N],q[N],c[N],ha[N],a