ZZNU 2095 : 我只看看不寫題
阿新 • • 發佈:2018-05-14
都是 code print ios color font tdi 有時 mat
把所有時間加起來,最後從大到小排序,一定要把大的先減去。註意花費的時間都是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\n",ans); } }
ZZNU 2095 : 我只看看不寫題