这道题一开始我没想什么直接开始染, 但是是for循环一个节点一个节点染, 然后就WA

后了看了https://www.cnblogs.com/jerryRey/p/4702323.html

发现原来还需要证明一下染色一定可以, 同时染色的方式是dfs

(1)证明

首先, 如果最大度数sum是偶数, 那么按照题目意思, k就为sum+1.

这个时候最坏情况下最大度数点与周围点的颜色都不一样, 需要sum+1种颜色, 也就是刚好是

k, 所以这种情况一定可以用k种颜色染完

其次, 如果最大度数sum是奇数的话, 此时k=sum, 最坏情况也是最大度数点与周围点的颜色都不一样。

但是这种情况可以证明是不存在的, 因为n为奇数

假设这种情况存在, 那么最大度数点u的一个相邻点v, 那么v一定有degree[u](u的度数)

个颜色不相同的点在v周围。为什么呢, 如果不是的话, 那么v的颜色就有多种可能

(没有被周围点限制), 那么就不满足前面所讲的最大度数点与周围点颜色不一样,

因为v可以为其他颜色。所以v一定有degree[u](u的度数)个颜色不相同的点在v周围。

那么可以推出u周围所有点都是这样, 同理u周围的点的周围点也是这样。

所以这个图是个完全图, 也就是说一个点和其他所有节点都可以直接连接。

那么, 前面说最大度数sum是奇数, 那么图中点的个数为sum+1(本身),

也就是点数为偶数。与题目给的n为奇数是矛盾的。

所以在最大度数sum是奇数这种情况下, 一定不存在最大度数点与周围点的颜色都不一样这

中情况(此时需要颜色数为sum+1), 也就是说需要颜色一定小于这种情况需要的颜色(需要颜色 < sum + 1) 

也就是 需要颜色<= sum = k, 所以k种颜色一定可以染完。

(2)染色方式

貌似dfs这样染周围的点的方式比较优。我之前用for循环遍历点来染色的方法会把后面的点“堵死”。

(3)另外, 学到了 a | 1是奇数不变, 偶数加1, 以及max_element的用法, 加上*表示指针的值

#include<cstdio>
#include<vector>
#include<cstring>
#include<algorithm>
#define REP(i, a, b) for(int i = (a); i <= (b); i++)
using namespace std; const int MAXN = 11234;
vector<int> g[MAXN];
int degree[MAXN], color[MAXN], vis[MAXN], n, m, k; void dfs(int u) //dfs染色
{
REP(i, 0, g[u].size() - 1)
vis[color[g[u][i]]] = u; REP(i, 1, k)
if(vis[i] != u)
{
color[u] = i;
break;
} REP(i, 0, g[u].size() - 1)
if(!color[g[u][i]])
dfs(g[u][i]);
} int main()
{
while(~scanf("%d%d", &n, &m))
{
REP(i, 1, n) g[i].clear();
memset(degree, 0, sizeof(degree));
memset(color, 0, sizeof(color));
memset(vis, 0, sizeof(vis)); while(m--)
{
int x, y;
scanf("%d%d", &x, &y);
g[x].push_back(y);
g[y].push_back(x);
degree[x]++; degree[y]++;
} k = (*max_element(degree+1, degree+n+1)) | 1; //偶+1, 奇不变。
dfs(1); // max_element求最大值, 返回指针 printf("%d\n", k);
REP(i, 1, n) printf("%d\n", color[i]);
puts("");
} return 0;
}

紫书 习题8-9 UVa 1613 (dfs染色+图的性质)的更多相关文章

  1. 【紫书】Oil Deposits UVA - 572 dfs求联通块

    题意:给你一个地图,求联通块的数量. 题解: for(所有还未标记的‘@’点) 边dfs边在vis数组标记id,直到不能继续dfs. 输出id及可: ac代码: #define _CRT_SECURE ...

  2. 紫书 习题 11-9 UVa 12549 (二分图最小点覆盖)

    用到了二分图的一些性质, 最大匹配数=最小点覆盖 貌似在白书上有讲 还不是很懂, 自己看着别人的博客用网络流写了一遍 反正以后学白书应该会系统学二分图的,紫书上没讲深. 目前就这样吧. #includ ...

  3. 紫书 习题 11-8 UVa 1663 (最大流求二分图最大基数匹配)

    很奇怪, 看到网上用的都是匈牙利算法求最大基数匹配 紫书上压根没讲这个算法, 而是用最大流求的. 难道是因为第一个人用匈牙利算法然后其他所有的博客都是看这个博客的吗? 很有可能-- 回归正题. 题目中 ...

  4. 紫书 习题8-12 UVa 1153(贪心)

    本来以为这道题是考不相交区间, 结果还专门复习了一遍前面写的, 然后发现这道题的区间是不是 固定的, 是在一个范围内"滑动的", 只要右端点不超过截止时间就ok. 然后我就先考虑有 ...

  5. 紫书 习题8-7 UVa 11925(构造法, 不需逆向)

    这道题的意思紫书上是错误的-- 难怪一开始我非常奇怪为什么第二个样例输出的是2, 按照紫书上的意思应该是22 然后就不管了,先写, 然后就WA了. 然后看了https://blog.csdn.net/ ...

  6. UVA 1613 K度图染色

    题目 \(dfs+\)证明. 对于题目描述,可以发现\(K\)其实就是大于等于原图中最大度数的最小奇数,因为如果原图度数最大为奇数,则最多颜色肯定为K,而如果原图最大度数为偶数,则\(K\)又是奇数, ...

  7. 紫书 习题7-13 UVa 817(dfs+栈求表达式的值)

    题目链接  点击打开链接 这道题分为两个部分, 一用搜索枚举每种可能, 二计算表达式的值, 有挺多细节需要注意 特别注意我的代码中在计算表达式的值中用到了一个!(代码枚举中的!表示不加符号, 我现在说 ...

  8. 紫书 习题 11-10 UVa 12264 (二分答案+最大流)

    书上写的是UVa 12011, 实际上是 12264 参考了https://blog.csdn.net/xl2015190026/article/details/51902823 这道题就是求出一种最 ...

  9. 紫书 习题 11-17 UVa 1670 (图论构造)

    一开始要符合题目条件, 那么肯定没有任何一个点是孤立的, 也就是说没有点的度数是1 所以我就想让度数是1的叶子节点相互连起来.然后WA 然后看这哥们的博客 https://blog.csdn.net/ ...

随机推荐

  1. 百度api使用说明

    .初始化地图,并设置地图中心点 复制代码 https://www.cnblogs.com/zqzjs/p/5293698.html var map = new BMap.Map("allma ...

  2. python matplotlib数据可视化

    #基于python3 Matplotlib构建的3D图形: 使用pycharm的小伙伴把sciview给关掉: 因为sciview显示的是png图片.3d图形一般我们都需要拖拖拽拽的. 参见: htt ...

  3. HDU 4458 Shoot the Airplane( 判断点在多边形内外 )

    链接:传送门 题意:这个游戏是一个2D打飞机游戏,飞机以速度 v 水平飞行,它是一个简单的多边形,玩家从( 0 , 0 )向上射击,子弹有一个出速度 b ,子弹可以看作一个点,打中飞机边缘是无法击落飞 ...

  4. 使用yum方式安装mysql5.6

    1.新开的云服务器,需要检测系统是否自带安装mysql # yum list installed | grep mysql 2.如果发现有系统自带mysql,果断这么干 # yum -y remove ...

  5. MHA 主从切换过程及日志分析

    本文主要在MHA 切换日志的角度分析MHA切换的过.MHA故障切换过程如下图所示 第一部分:开启MHA 监控 通过分析日志,得到以下步骤: 1.读取MHA manager 节点的配置文件,并检查配置文 ...

  6. 安装Nginx的各种报错的解决

    如题,本人环境Ubuntu14.0虚拟机,安装一个nginx服务器来运行我的fastDfs文件管理的.但是安装出现了各种问题: sudo ./configure --prefix=/usr/local ...

  7. 启用Maven的代理访问

    1. Maven配置文件 找到文件 {M2_HOME}/conf/settings.xml, 并把你的代理服务器信息配置写入.注:{M2_HOME} => D:\software\yiibai. ...

  8. 洛谷 P1029 最大公约数和最小公倍数问题

    有两种做法 一种是gcd与lcm相乘后就是两个数的乘积,枚举第一个数,算出第二数,看最大公约数是不是题目给的. 第二种就lcm/gcd的答案为两个互质的数相乘.然后就枚举有多少组互质的数相乘等于lcm ...

  9. 【 henuacm2016级暑期训练-动态规划专题 A 】Cards

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 很显然只要维护B,R,G的数量就好了. 可以很容易想到一个dfs(int a,int b,int c) 然后如果a+b+c==1,那 ...

  10. 华硕VX50V开机老是进入bios

    问题:华硕VX50V开机老是进入bios 如图: 解决办法: 1.将   Boot  中的--->>  Lunch CSM  ---->>设置为  -->> ena ...