首先这个题目名什么鬼..奇怪的语言
嘛..正解是线段树优化构图最大费用流..smg
似乎可以贪心一下,因为Hungary当前这个节点的时候不会取消以前匹配的节点,所以直接按权值排序匈牙利。
速度竟然虐了网络流……
n3
的复杂度啊.
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<queue>
#include<vector>
#include<map>
#include<set>
#include<algorithm>
#include<iostream>
#define N 5005
#define ll long long
using namespace std;
int sc()
{
int i=0,f=1; char c=getchar();
while(c>'9'||c<'0'){if(c=='-')f=-1;c=getchar();}
while(c>='0'&&c<='9')i=i*10+c-'0',c=getchar();
return i*f;
}
struct W{int l,r,v;}a[N];
int from[N],TI[N],mx,T,n,ans;
bool cmp(W a,W b){return a.v>b.v;}
bool Hungary(int x)
{
TI[x]=T;
for(int i=a[x].l;i<=a[x].r;i++)
if(!from[i]||(TI[from[i]]!=T&&Hungary(from[i])))
{
from[i]=x;
return 1;
}
return 0;
}
int main()
{
n=sc();
for(int i=1;i<=n;i++)
a[i].l=sc(),a[i].r=sc()-1,a[i].v=sc();
sort(a+1,a+n+1,cmp);
for(int i=1;i<=n;i++)
{
T++;
if(Hungary(i)) ans+=a[i].v;
}
cout<<ans;
return 0;
}