题目大意:给一张$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;
}

  

最新文章

  1. ecshop /pick_out.php SQL Injection Vul By Local Variable Overriding
  2. flex模拟微信布局
  3. Python开发【第二章】:Python模块和运算符
  4. Spring &lt;bean&gt; 参数意义
  5. IE7 -- 鼠标移入显示下拉框 不显示的问题 / 以及宽度问题
  6. HDU 3711 Binary Number
  7. 100% opacity UILabel over a 50% opacity background (UIView?) UIView是百分之50透明而上面的UILable是100%不透明
  8. 关于Discuz!nt论坛编辑器图片上传bug,flash域的问题
  9. Cmake,链接一个外部(也可能是第三方,也可能是自己编译的)库
  10. Bash shell 的算术运算有四种方式
  11. u-boot源码下载
  12. [原创] 利用前端+php批量生成html文件,传入新文本,输出新的html文件
  13. Cow Uncle 学习了叉积的一点运用,叉积真的不错
  14. BZOJ 4216: Pig [分块]
  15. jdbc连接oracle时报错 Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableC
  16. 记录一次JQuery 动态参数使用
  17. spring cloud 学习(二)关于 Eureka 的学习笔记
  18. 关于在浏览器中测试cordova plugin的注意事项。
  19. 黑马程序员_java基础笔记(02)...java语言基础组成
  20. SDN定义网络

热门文章

  1. SAP 文本框实例
  2. linux下后台运行jar包
  3. mysql基础 日期类型
  4. Linux基础知识随笔记
  5. juicer
  6. 3.4.2 Undefined类型【JavaScript高级程序设计第三版】
  7. JZOJ 5914. 盟主的忧虑
  8. 笔记-git-基础使用
  9. hihocoder #1394 : 网络流四&#183;最小路径覆盖(最小路径覆盖)
  10. hadoop中namenode发生故障的处理方法