HDU 3488 KM Tour
2024-09-07 20:54:02
这题注意有重边。。
#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 ;
}
代码君
最新文章
- Python字符串的encode与decode研究心得乱码问题解决方法
- MySQL 利用SQL线程对Binlog操作
- wicket基本控件使用笔记
- emberjs创建类
- uva 11292 Dragon of Loowater (勇者斗恶龙)
- Keil uCos 2.52 stm32 【worldsing笔记】
- shell脚本中>;/dev/null的含义
- Android 开发笔记 “The constructor AlertDialog.Builder(new View.OnKeyListener(){}) is undefined”
- jQuery控制元素隐藏和显示
- 【原】spring boot添加cros全局过滤器
- java的io库用到的装饰模式是如何体现的?
- C#之Redis所欲为
- thinter中combobox下拉选择控件(九)
- C语言中#undef作用
- 通用查询类封装之Mongodb篇
- Django“少折腾”
- 《python for data analysis》第八章,绘图与可视化
- SpringMVC学习笔记_02
- 【转】escape()、encodeURI()、encodeURIComponent()区别详解
- [转帖学习]Oracle的 SYS_CONTEXT 函数简介