Files
OI-source/2.1613.cpp
2023-08-03 09:22:52 +08:00

114 lines
2.4 KiB
C++

#include<iostream>
#include<cstdio>
#include<cmath>
#include<queue>
#include<cstring>
using namespace std;
int degree[10055]; //记录每一个顶点的度数
int color[10055]; //记录每一个顶点的颜色
int maxDegree; //记录最大度数
/************
图论常用: 链式向前星 -->邻接表记录 图结构
***********/
int head[10055];
struct e{
int v , nxt;
}edge[200505];
int Ecnt;
void addEdge(int u , int v){
edge[Ecnt].v = v;
edge[Ecnt].nxt = head[u];
head[u]=Ecnt++;
}
int colorUsed[10005];//该颜色是否被相邻的顶点用过
int used[10055]; //该顶点是否 进入过队列
void BFS(int src){
queue<int> q;
q.push(src);
memset(used , 0 ,sizeof(used));
used[src] =1;
while(!q.empty()){
int index = q.front();
q.pop();
memset(colorUsed , 0 , sizeof(colorUsed));
for(int i=head[index] ; i!=-1 ; i=edge[i].nxt){
int v = edge[i].v;
if(color[v]!=-1) { //记录下 周围顶点已经 用过的颜色
colorUsed[color[v]]=1;
}else if(used[v] == 0){ //若 周围顶点未进入过 队列 则入队
used[v] = 1;
q.push(v);
}
}
int j;
for(j=1 ;j<=maxDegree ; ++j){//用最小的 未被用过颜色 来涂当前顶点
if(!colorUsed[j]){
color[index] = j;
break;
}
}
}
}
//初始化
void Init(){
Ecnt = 0 ;
maxDegree = 0;
memset(head , -1 , sizeof(head));
memset(degree , 0 ,sizeof(degree));
memset(color , -1 ,sizeof(color));
}
int main(){
bool first = true;
int n, m;
while(scanf("%d %d",&n , &m)!=EOF){
Init();
if (first)
first = false;
else
printf("\n");
int u ,v;
for(int i=0 ; i<m ; ++i){
scanf("%d %d",&u,&v);
if(u == v) continue;
addEdge(u,v);
addEdge(v,u);
degree[u]++;
degree[v]++;
}
for(int i=1 ;i<=n ; ++i){
if(maxDegree < degree[i]){
maxDegree = degree[i];
}
}
if(maxDegree%2 == 0) maxDegree++;
BFS(1);
printf("%d\n",maxDegree);
for(int i=1 ;i<=n ;++i)
printf("%d\n",color[i]);
}
return 0;
}