参考题解

这题注意有重边。。

 #include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int maxn = + ; int n, m;
int W[maxn][maxn], lft[maxn];
int Lx[maxn], Ly[maxn];
bool S[maxn], T[maxn];
int slack[maxn]; bool match(int u)
{
S[u] = true;
for(int v = ; v <= n; v++) if(!T[v])
{
int t = Lx[u] + Ly[v] - W[u][v];
if( == t)
{
T[v] = true;
if(!lft[v] || match(lft[v]))
{
lft[v] = u;
return true;
}
}
else slack[v] = min(slack[v], t);
}
return false;
} void update()
{
int a = ;
for(int i = ; i <= n; i++) if(!T[i]) a = min(a, slack[i]);
for(int i = ; i <= n; i++)
{
if(S[i]) Lx[i] -= a; if(T[i]) Ly[i] += a;
else slack[i] -= a;
}
} void KM()
{
memset(lft, , sizeof(lft));
memset(Lx, 0x80, sizeof(Lx));
memset(Ly, , sizeof(Ly));
for(int i = ; i <= n; i++)
for(int j = ; j <= n; j++)
Lx[i] = max(Lx[i], W[i][j]); for(int i = ; i <= n; i++)
{
memset(slack, 0x3f, sizeof(slack));
for(;;)
{
memset(S, false, sizeof(S));
memset(T, false, sizeof(T));
if(match(i)) break;
else update();
}
}
} int main()
{
int T; scanf("%d", &T); while(T--)
{
scanf("%d%d", &n, &m);
memset(W, 0x80, sizeof(W));
for(int i = ; i < m; i++)
{
int u, v, d; scanf("%d%d%d", &u, &v, &d);
W[u][v] = max(W[u][v], -d);
} KM(); int ans = ;
for(int i = ; i <= n; i++) ans += W[lft[i]][i];
printf("%d\n", -ans);
} return ;
}

代码君

最新文章

  1. Python字符串的encode与decode研究心得乱码问题解决方法
  2. MySQL 利用SQL线程对Binlog操作
  3. wicket基本控件使用笔记
  4. emberjs创建类
  5. uva 11292 Dragon of Loowater (勇者斗恶龙)
  6. Keil uCos 2.52 stm32 【worldsing笔记】
  7. shell脚本中&gt;/dev/null的含义
  8. Android 开发笔记 “The constructor AlertDialog.Builder(new View.OnKeyListener(){}) is undefined”
  9. jQuery控制元素隐藏和显示
  10. 【原】spring boot添加cros全局过滤器
  11. java的io库用到的装饰模式是如何体现的?
  12. C#之Redis所欲为
  13. thinter中combobox下拉选择控件(九)
  14. C语言中#undef作用
  15. 通用查询类封装之Mongodb篇
  16. Django“少折腾”
  17. 《python for data analysis》第八章,绘图与可视化
  18. SpringMVC学习笔记_02
  19. 【转】escape()、encodeURI()、encodeURIComponent()区别详解
  20. [转帖学习]Oracle的 SYS_CONTEXT 函数简介

热门文章

  1. HandlerMapping执行过程。。。
  2. dubbo服务降级(1)
  3. java构造方法之我见
  4. http://circles.arenaofthemes.com/
  5. 帝国empirecms数据库数据表详细说明
  6. 织梦DEDECMS会员中心发布文章修改提示"数据校验不对,程序返回"
  7. 织梦修改文档HTML默认保存路径
  8. Android 4.4及以后将内容布局延伸到状态栏
  9. iOS - NSString 封装
  10. 安卓中Paint类和Canvas类的方法汇总