zznuoj2095我只看看不写题

2095 : 我只看看不写题

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

提交 状态 讨论区

题目描述

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

输入

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

输出

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

样例输入

复制
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//C++万能头文件,不过部分oj不支持
using namespace std;
struct GG
{
 int sti,time;
}num[100003];
bool cmp(GG x,GG y)
{
 return x.time < y.time;
}
int main()
{
 int t;
 scanf("%d",&t);
 while (t--)
 {
  int n,m,i,ans = 0,pos,sum = 0;
  scanf("%d %d",&n,&m);
  for (i = 0;i < n;i ++)
   scanf("%d %d",&num[i].sti,&num[i].time),sum += num[i].sti;
  sort(num,num + n,cmp);
  priority_queue q;
  pos = n - 1;
  for (i = m;i > 0;i --)
  {
   while (num[pos].time >= i) q.push(num[pos].sti),pos --;
   if (!q.empty())
    ans += q.top(),q.pop();
  }
  printf("%d\n",sum - ans);
 }
 return 0;
}

你可能感兴趣的:(数据结构)