1. 程式人生 > >ZZNU 2095 : 我只看看不寫題

ZZNU 2095 : 我只看看不寫題

都是 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 : 我只看看不寫題