zznu 我只看看不写题(贪心+优先队列)

G : 我只看看不写题

Progress Bar

时间限制:1 Sec 内存限制:128 MiB
提交:155 答案正确:39

提交


题目描述

 
 
伴随着科技的发展,我们的生活也越来越多姿多彩,随着手机的普及,各种交友软件也在快速的发展。
小a是个老实人,当然只是自己理解而已,其实小a是个不折不扣的渣男。因为他在有女朋友的同时,还在疯狂的撒网,利用各种交友软件寻求更适合自己的伴侣。
小a女朋友当然不是省油的灯,自然了解小a的本性,所以在每次见面时就会翻看小a的软件记录,来了解小a近期的状况,机智的小a当然会在女朋友来之前就给完全清理干净了。
终于在某次时间紧急的情况下,小a的软件记录并不一定能够完全删除,但是小a知道,自己每个软件记录的火热程度以及最终删除时间(即可以删除的最晚时间,过时将无法删除)。每个软件记录的删除需要一分钟,软件记录的火热程度,正好对应着女朋友的刺激值,小a想知道,在有限的时间内,如何才能够让女朋友的刺激值最小,求出最小值。

输入

 
 
第一行一个正整数T。表示样例个数(0<T<10)
每组有两个整数n,m,分别表示一共有n个软件以及女朋友到来的时间(0<n<=10^5,0<m<=10^6)
往下对应着n行,每行有两个正整数e,f分别对应每个软件记录的火热程度和该软件的最终删除时间。(0<e<=10^5,0<f<=10^6)
题目中涉及到的时间全部以分钟为单位。

输出

	输出对女朋友的最小刺激值;结果占一行。

样例输入

复制
2
4 2
20 1
10 1
30 2
40 2
6 2
20 1
10 1
30 2
40 2
50 3
60 3

样例输出

复制
30
100
  1. #include<stdio.h>  
  2. #include<algorithm>  
  3. #include<queue>  
  4. using namespace std;  
  5. #define ll long long  
  6. struct Node{  
  7.     int score,time;  
  8.     friend bool operator < (const Node &a,const Node &b){  
  9.     return a.score<b.score;  
  10.     }  
  11. }node[100005];  
  12. int cmp(Node a,Node b){  
  13.     return a.time>b.time;  
  14. }  
  15. int main(){  
  16.     int t;  
  17.     scanf("%d",&t);  
  18.     while(t--){  
  19.         int n,m;  
  20.         scanf("%d%d",&n,&m);  
  21.         ll ans=0,sum=0;  
  22.         for(int i=1;i<=n;i++){  
  23.             scanf("%d%d",&node[i].score,&node[i].time);  
  24.             sum+=node[i].score;  
  25.         }  
  26.         sort(node+1,node+1+n,cmp);  
  27.           
  28.         int j=1;  
  29.         priority_queue<Node>q;  
  30.         for(int i=m;i>=1;i--){  
  31.             while(node[j].time>=i&&j<=n){  
  32.                 q.push(node[j++]);  
  33.             }  
  34.             if(!q.empty()){  
  35.                 ans=ans+q.top().score;  
  36.                 q.pop();  
  37.             }  
  38.         }  
  39.         printf("%lld\n",sum-ans);  
  40.     }  
  41.     return 0;  
  42. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值