//网络流判定混合图欧拉回路
//通过网络流使得各点的出入度相同则possible,否则impossible
//残留网络的权值为可改变方向的次数,即n个双向边则有n次
//Time:157Ms Memory:348K
#include <iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std;
#define MAXN 205
#define INF 0x3f3f3f3f
int n,m;
int s,t;
int dif[MAXN];
int res[MAXN][MAXN]; //残留网络-代表可变方向数
int pre[MAXN];
bool bfs()
{
memset(pre,-1,sizeof(pre));
queue<int> q;
q.push(s); pre[s] = 0;
while(!q.empty()){
int cur = q.front();
q.pop();
for(int i = 1; i <= t; i++)
{
if(pre[i] == -1 && res[cur][i])
{
pre[i] = cur;
if(i == t) return true;
q.push(i);
}
}
}
return false;
}
int EK()
{
int maxFlow = 0;
while(bfs()){
int mind = INF;
for(int i = t; i != s; i = pre[i])
mind = min(mind, res[pre[i]][i]);
for(int i = t; i != s; i = pre[i])
{
res[pre[i]][i] -= mind;
res[i][pre[i]] += mind;
}
maxFlow += mind;
}
return maxFlow;
}
int main()
{
//freopen("in.txt", "r", stdin);
int T;
scanf("%d", &T);
while(T--){
memset(dif,0,sizeof(dif));
memset(res,0,sizeof(res));
scanf("%d%d", &n, &m);
int total = 0;
s = 0; t = n+1;
for(int i = 0; i < m; i++)
{
int u,v,t;
scanf("%d%d%d", &u,&v,&t);
dif[u]++; dif[v]--;
if(t == 0) res[u][v] += 1; //重边则可变方向+1
}
bool flag = true;
for(int i = 1; i <= n; i++)
{
if(dif[i] > 0) { //出度多-通过源点给予奇数入度
res[s][i] = dif[i]/2;
total += dif[i]/2;
}
if(dif[i] < 0) res[i][t] = -dif[i]/2; //入度多-通过汇点给予奇数出度
if(abs(dif[i]) % 2 == 1)
{
flag = false;
break;
}
}
(flag && EK() == total)? printf("possible\n"): printf("impossible\n");
}
return 0;
}

最新文章

  1. SQL Pretty Printer-不错的SQL格式化工具
  2. zeromq 学习和python实战
  3. 【CodeForces 602C】H - Approximating a Constant Range(dijk)
  4. 【转】ubuntu下安装eclipse以及配置python编译环境
  5. Python函数小结(2)-- 装饰器、 lambda
  6. 使用MYCAT作为Mysql HA的中间件(转)
  7. Gradle 载入中 Android 下一个.so档
  8. L2-001. 紧急救援
  9. [UIKit学习]02.关于UIButton
  10. org.springframework.beans.factory.BeanDefinitionStoreException: Failed to read candidate component class: file [/Users/lonecloud/tomcat/apache-tomcat-7.0.70 2/webapps/myproject/WEB-INF/classes/cn/lone
  11. 我的Windows日常——你的小电影藏好了吗?
  12. telnet-server、telnet
  13. 对spring框架的理解
  14. 手机号读取城市数据库2018年3月excel版
  15. 凭什么相信你,我的CNN模型
  16. Spring Boot重要内容
  17. ABP框架系列之十九:(Debugging-调试)
  18. 使用onpaste粘贴事件引起的探索
  19. rcp(插件开发)插件B需要引用插件A中的jar包-如何处理依赖关系
  20. 命令行运行python项目文件,报错:ModuleNotFoundError: No module named &#39;xxxx&#39; 解决办法

热门文章

  1. BAD APPLE C++控制台程序
  2. try catch中用了 Response.Redirect 引发的线程异常终止
  3. JDK历史版本
  4. 微信JSSDK javascript 开发 代码片段,仅供参考
  5. asp.net mvc短信接口调用——阿里大于API开发心得
  6. GitHub新手快速入门日常操作流程
  7. js ie中实现拖拽
  8. MAC &amp;&amp; Linux terminal session clone
  9. WebService学习总结(四)——调用第三方提供的webService服务
  10. jQuery中 pageX,clientX,offsetX,layerX的区别