2015 多校联赛 ——HDU5348(搜索)
来源:互联网 发布:数据分析师需要学什么 编辑:程序博客网 时间:2024/05/14 12:39
Problem Description
As we all kown, MZL hates the endless loop deeply, and he commands you to solve this problem to end the loop.
You are given an undirected graph withn vertexs and m edges. Please direct all the edges so that for every vertex in the graph the inequation |out degree − in degree|≤1 is satisified.
The graph you are given maybe contains self loops or multiple edges.
You are given an undirected graph with
The graph you are given maybe contains self loops or multiple edges.
Input
The first line of the input is a single integer T , indicating the number of testcases.
For each test case, the first line contains two integersn and m .
And the nextm lines, each line contains two integers ui and vi , which describe an edge of the graph.
T≤100 , 1≤n≤105 , 1≤m≤3∗105 , ∑n≤2∗105 , ∑m≤7∗105 .
For each test case, the first line contains two integers
And the next
Output
For each test case, if there is no solution, print a single line with −1 , otherwise output m lines,.
Ini th line contains a integer 1 or 0 , 1 for direct the i th edge to ui→vi , 0 for ui←vi .
In
Sample Input
23 31 22 33 17 61 21 31 41 51 61 7
Sample Output
111010101
题:给出n个点,m条无向边,现在要求将无向边变为有向边,要保证每个点的出度和入度的差不超过1
思路来自:http://blog.csdn.net/winddreams/article/details/47281397
直接进行搜索,对每个点进行出度和入度的判断,如果出度大,就先进行反向的搜索(每搜索一条边u,v就认为这是一条v到u的有向边),反之,进行正向搜索(每搜到一条边u,v认为这是一条u到v的有向边),一直搜索到找不到边能继续为止。
对于已经判断过的边删去:head[u] = edge[i].next;
证明不会有-1的情况,对于一个点v,假设入度比出度多2,那么,第一:就会有一条边搜索到v后找不到后继,导致v的入度比出度多1,第二:又有一条边搜索到v,导致v的入度比出度多2,但是这样的话就会和第一条找不到后继冲突,所以不会出现入度比出度多2的情况,(其他情况也是类似),所以不会有-1的结果。
(果然稍难一点自己就不知道怎么办了 好坑orz)
#include <iostream>#include <cstdio>#include<algorithm>#include<cstring>#include<functional>#include<queue>typedef long long ll;using namespace std;struct node{ int u,v,ci; int next;} edge[700000];int n,m,to;int head[100010] , vis[700000] ;int in[100010] , out[100010] , num[100010] ;int ans[700000] ;void add(int u,int v,int c){ edge[to].u= u; edge[to].v= v; edge[to].ci = c; edge[to].next = head[u]; head[u] = to++;}void dfs1(int u) //正向搜索{ for(int i = head[u]; ~i; i = edge[i].next) { if(vis[i]) { head[u] = edge[i].next; //删边 continue; } int v = edge[i].v; if(u != v && in[v] > out[v]) //u->v,in[v] > out[v]时,跳过 continue; vis[i] = vis[i^1] = 1; //将u,v之间的两条边标记 if(i %2) //有输入可知,i为偶时u->v; i为奇时,v->u ans[i/2] = 0; else ans[i/2] = 1; out[u]++; in[v]++; head[u] = edge[i].next; dfs1(v); break; }}void dfs2(int u){ for(int i = head[u]; ~i; i = edge[i].next) { if(vis[i]) { head[u] = edge[i].next; continue; } int v = edge[i].v; if(u != v && in[v] < out[v]) continue; vis[i] = vis[i^1] = 1; if(i %2) ans[i/2] = 1; else ans[i/2] = 0; out[v]++; in[u]++; head[u] = edge[i].next; dfs2(v); break; }}int main(){ int T; int a, b; scanf("%d",&T); while(T--) { to = 0; scanf("%d%d",&n,&m); memset(vis,0,sizeof(vis)); for(int i = 0;i <= n;i++) { in[i] = out[i] = num[i] = 0;head[i] = -1; } for(int i = 0; i < m; i++) { scanf("%d%d",&a,&b); add(a,b,i); add(b,a,i); num[a]++; num[b]++; } for(int i = 1; i <= n; i++) { while(in[i] + out[i] < num[i]) { if(in[i] >= out[i]) //正反不停搜,直到找不到边为止 dfs1(i); else dfs2(i); } } for(int i = 0; i < m; i++) printf("%d\n",ans[i]); } return 0;}
0 0
- 2015 多校联赛 ——HDU5348(搜索)
- 2015 多校联赛 ——HDU5305(搜索)
- 2015 多校联赛 ——HDU5323(搜索)
- hdu5348(2015多校5)--MZL's endless loop(搜索)
- 2015 多校联赛 ——HDU5289(二分+ST)
- 2015多校联赛 ——HDU5288(数学)
- 2015 多校联赛 ——HDU5299(树删边)
- 2015 多校联赛 ——HDU5303(贪心)
- 2015 多校联赛 ——HDU5301(技巧)
- 2015 多校联赛 ——HDU5319(模拟)
- 2015 多校联赛 ——HDU5316(线段树)
- 2015 多校联赛 ——HDU5325(DFS)
- 2015 多校联赛 ——HDU5302(构造)
- 2015 多校联赛 ——HDU5335(Walk out)
- 2015 多校联赛 ——HDU5334(构造)
- 2015 多校联赛 ——HDU5344(水)
- 2015 多校联赛 ——HDU5349(水)
- 2015 多校联赛 ——HDU5350(huffman)
- python socket的代码实例
- C/C++是怎么通过宏定义来判断操作系统的
- spfa hdu1317 XYZZY
- FastJson---高性能JSON开发包
- CodeForces 1C - Ancient Berland Circus
- 2015 多校联赛 ——HDU5348(搜索)
- java常用类:Number|日期|Character|String|StringBuffer
- 20150805
- Spring 注解的方式进行事务管理
- 南邮 OJ 1216 集合划分问题II
- 上传文件到Github
- 用Database Configuration Assistant (DBCA)配置oracle(中文)
- iOS开发之获取沙盒路径
- 微信红包程序 java