[LOJ #2162]「POI2011」Garbage
题目大意:给一张$n$个点$m$条边的无向图,每条边是黑色的或白色的,要求变成一个目标颜色。可以从任意一个点开始,走一个简单环,回到开始的点,所经过的边颜色翻转。可以走无数次。问是否有一个方案完成目标。有则输出任意方案。
题解:不用改变颜色的边不用管,因为可以通过走两个环使得这条边经过两次,而剩下的部分会拼成一个大环。
即要求是找互不相交的环,使得构成整张图
卡点:1.输出格式要求起点输出两次
2.找到环后不可以退出
C++ Code:
#include <cstdio>
#include <vector>
#define maxn 100010
#define maxm 1000010
int head[maxn], cnt = 1;
struct Edge {
int to, nxt;
bool vis;
} e[maxm << 1];
inline void add(int a, int b) {
e[++cnt] = (Edge) {b, head[a], false}; head[a] = cnt;
} int n, m, ind[maxn];
int CNT, num[maxn];
std::vector<int> ans[maxn];
int S[maxn], top;
bool ins[maxn];
void dfs(int u) {
int v;
if (ins[u]) {
CNT++;
do {
num[CNT]++;
ins[v = S[top--]] = false;
ind[v] -= 2;
ans[CNT].push_back(v);
} while (v != u);
}
ins[S[++top] = u] = true;
for (int &i = head[u]; i; i = e[i].nxt) {
if (!e[i].vis) {
v = e[i].to;
e[i].vis = e[i ^ 1].vis = true;
dfs(v);
return ;
}
}
ins[u] = false;
} int main() {
scanf("%d%d", &n, &m);
for (int i = 0, a, b, c, d; i < m; i++) {
scanf("%d%d%d%d", &a, &b, &c, &d);
if (c != d) {
ind[a]++, ind[b]++;
add(a, b);
add(b, a);
}
}
for (int i = 1; i <= n; i++) if (ind[i] & 1) {
puts("NIE");
return 0;
}
for (int i = 1; i <= n; i++) while (ind[i]) dfs(i);
printf("%d\n", CNT);
for (int i = 1; i <= CNT; i++) {
printf("%d", num[i]);
for (int j = 0; j < num[i]; j++) printf(" %d", ans[i][j]);
printf(" %d\n", ans[i][0]);
}
return 0;
}
[LOJ #2162]「POI2011」Garbage的更多相关文章
- LOJ#2170. 「POI2011」木棍 Sticks
题目链接 题意就是给你一堆线段,然后线段有长度和颜色,让你选三条组成一个三角形,这三条线段颜色不能一样 题解: 做法:贪心 首先按照长度给这些线段排序一遍 然后贪心的去选,对于已经选出来同种颜色的,就 ...
- Loj #2192. 「SHOI2014」概率充电器
Loj #2192. 「SHOI2014」概率充电器 题目描述 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品--概率充电器: 「采用全新纳米级加工技术,实现元件与导线能否通电完 ...
- Loj #3096. 「SNOI2019」数论
Loj #3096. 「SNOI2019」数论 题目描述 给出正整数 \(P, Q, T\),大小为 \(n\) 的整数集 \(A\) 和大小为 \(m\) 的整数集 \(B\),请你求出: \[ \ ...
- Loj #3093. 「BJOI2019」光线
Loj #3093. 「BJOI2019」光线 题目描述 当一束光打到一层玻璃上时,有一定比例的光会穿过这层玻璃,一定比例的光会被反射回去,剩下的光被玻璃吸收. 设对于任意 \(x\),有 \(x\t ...
- Loj #3089. 「BJOI2019」奥术神杖
Loj #3089. 「BJOI2019」奥术神杖 题目描述 Bezorath 大陆抵抗地灾军团入侵的战争进入了僵持的阶段,世世代代生活在 Bezorath 这片大陆的精灵们开始寻找远古时代诸神遗留的 ...
- Loj #2542. 「PKUWC2018」随机游走
Loj #2542. 「PKUWC2018」随机游走 题目描述 给定一棵 \(n\) 个结点的树,你从点 \(x\) 出发,每次等概率随机选择一条与所在点相邻的边走过去. 有 \(Q\) 次询问,每次 ...
- Loj #3059. 「HNOI2019」序列
Loj #3059. 「HNOI2019」序列 给定一个长度为 \(n\) 的序列 \(A_1, \ldots , A_n\),以及 \(m\) 个操作,每个操作将一个 \(A_i\) 修改为 \(k ...
- Loj #3056. 「HNOI2019」多边形
Loj #3056. 「HNOI2019」多边形 小 R 与小 W 在玩游戏. 他们有一个边数为 \(n\) 的凸多边形,其顶点沿逆时针方向标号依次为 \(1,2,3, \ldots , n\).最开 ...
- Loj #3055. 「HNOI2019」JOJO
Loj #3055. 「HNOI2019」JOJO JOJO 的奇幻冒险是一部非常火的漫画.漫画中的男主角经常喜欢连续喊很多的「欧拉」或者「木大」. 为了防止字太多挡住漫画内容,现在打算在新的漫画中用 ...
随机推荐
- babel 不能统编译Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise的问题
Babel默认只转换新的JavaScript句法(syntax),而不转换新的API,比如Iterator.Generator.Set.Maps.Proxy.Reflect.Symbol.Promis ...
- 使用 W3C Performance 对象通过 R 和 JavaScript 将浏览器内的性能数据可视化[转]
当考虑 Web 性能指标时,需要关注的目标数字应该是从您自己的用户那里获得的实际用户指标.最常见的方法是利用 Splunk 之类的工具来分析您的机器数据,该工具支持您分析和可视化您的访问权限和错误日志 ...
- ant Design表单验证笔记
1.pattern正则验证 <Col md={12} sm={24}> <FormItem {...formItemLayout} label="班数"> ...
- 深入浅出:了解JavaScript的ES6、ES7新特性
参照阮一峰博客:http://es6.ruanyifeng.com/#README es6常见题:https://blog.csdn.net/qq_39207948/article/details/8 ...
- C++的队列和pair
C++队列的成员函数: back()返回最后一个元素 empty()如果队列空则返回真 front()返回第一个元素 pop()删除第一个元素 push()在末尾加入一个元素 size()返回队列中元 ...
- 使用select2 宽度自适应
加一个CSS属性:style = "width : 100%"
- Centos7-Mysql-5.6.41一主两从的搭建
01.准备工作 首先的前提条件你必须安装了mysql,而且知道你安装mysql配置文件的位置,接下来的事情就好办了. 我的搭建环境: 服务器1: 10.233.17.20 mysql-master(主 ...
- scrapy--selenium
一直在学习scrapy的爬虫知识,但是遇到了动态加载页面的难题,从一开始的javascript渲染器--splash,docker服务, 遇到各种奇葩的问题: 1.docker代理设置添加无效,导致无 ...
- anaconda+jupyter notebook 安装配置
安装Anaconda 从清华大学开源软件镜像站选择合适自己的版本 wget https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/Anaconda ...
- PHP 7.1版本 微信安全模式消息接受
token 验证就不多讲了 重点说一下PHP7.1版本的加密解密算法 php7.1发布后新特性吸引了不少PHPer,大家都在讨论新特性带来的好处与便利. 但是从php7.0 升级到 php7.1 废弃 ...