题目描述
伴随着科技的发展,我们的生活也越来越多姿多彩,随着手机的普及,各种交友软件也在快速的发展。
小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
- #include<stdio.h>
- #include<algorithm>
- #include<queue>
- using namespace std;
- #define ll long long
- struct Node{
- int score,time;
- friend bool operator < (const Node &a,const Node &b){
- return a.score<b.score;
- }
- }node[100005];
- int cmp(Node a,Node b){
- return a.time>b.time;
- }
- int main(){
- int t;
- scanf("%d",&t);
- while(t--){
- int n,m;
- scanf("%d%d",&n,&m);
- ll ans=0,sum=0;
- for(int i=1;i<=n;i++){
- scanf("%d%d",&node[i].score,&node[i].time);
- sum+=node[i].score;
- }
- sort(node+1,node+1+n,cmp);
- int j=1;
- priority_queue<Node>q;
- for(int i=m;i>=1;i--){
- while(node[j].time>=i&&j<=n){
- q.push(node[j++]);
- }
- if(!q.empty()){
- ans=ans+q.top().score;
- q.pop();
- }
- }
- printf("%lld\n",sum-ans);
- }
- return 0;
- }