把所有时间加起来,最后从大到小排序,一定要把大的先减去。注意花费的时间都是1,这一秒用过就不能再用了,所有用到了并查集的部分知识
#include<iostream> #include<cstdio> #include<cstdlib> #include<cstring> #include<cmath> #include<vector> #include<algorithm> #include<ctime> using namespace std; struct DD { int s,t; }A[100005]; bool cmp(DD a,DD b) { return a.s>b.s; } int f[1000001]; int getf(int v) { if(f[v]==-1) return v; return f[v]=getf(f[v]); } int main() { int t,n,m,i,j; scanf("%d",&t); while(t--) { long long ans=0; scanf("%d%d",&n,&m); for(i=0;i<=m;i++) f[i]=-1; for(i=0;i<n;i++) { scanf("%d%d",&A[i].s,&A[i].t); ans+=A[i].s; if(A[i].t>m) A[i].t=m; } sort(A,A+n,cmp); int tt=0; for(i=0;i<n;i++) { if(tt>=m) break; int x=getf(A[i].t); if(x>0) { ans-=A[i].s; f[A[i].t]=x-1; tt++; } } printf("%lld ",ans); } }