码迷,mamicode.com
首页 > 其他好文 > 详细

Alisha’s Party---hdu5437(模拟+优先队列)

时间:2016-08-03 23:41:05      阅读:191      评论:0      收藏:0      [点我收藏+]

标签:

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5437

题意:公主有k个朋友来参加她的生日party,每个人都会带价值为v[i]的礼物过来,在所有人到齐之前公主会打开大门m次,每次开门就是在第t个人到来之后,然后让p个人进入大厅,如果当前人数不足p人,则让所有人都进去,最后在所有人都来到门口时,再次打开门,让剩下所有的人都进入大厅;当然选择礼物价值大的先进入,如果两个人的礼物价值相等,则先来的先进,现在有q个问题,问第ni个进入大厅的人是谁;

我们可以用优先队列存入每次开门可以进去的人,然后按顺序依次进入p个人,模拟,注意细节即可;

技术分享
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <string>
#include <vector>
#include <algorithm>
#include <map>
#include <queue>
#include <stack>
#include <math.h>

using namespace std;

#define met(a, b) memset(a, b, sizeof(a))
#define N 150003
#define INF 0x3f3f3f3f

typedef long long LL;

struct node
{
    int Time, v;
    char Name[210];
    friend bool operator < (node p, node q)
    {
        if(p.v != q.v)
            return p.v < q.v;
        return p.Time > q.Time;
    }
}a[N];

struct Open
{
    int t, cnt;
    bool friend operator < (Open p, Open q)
    {
        return p.t < q.t;
    }
}b[N];

int n, m, q;

char ans[N][210];

void solve()
{
    priority_queue<node> Q;///优先队列注意优先级;

    node p;

    int j = 1, k = 1;

    for(int i=1; i<=m; i++)
    {
        while(j <= b[i].t && j<=n)///把此次开门能进去的先放入队列;
        {
            Q.push(a[j]);
            j++;
        }
        int num = b[i].cnt;

        while(!Q.empty() && num --)///每次进num个人,如果不足num就是全进入,进入大厅,即出队列;
        {
            p = Q.top();
            Q.pop();
            strcpy(ans[k++], p.Name);
        }
    }
    while(j<=n)///把剩下没有进入队列的放入队列;
    {
        Q.push(a[j]);
        j++;
    }
    while(!Q.empty())///当所有人都到了之后,再次打开门,让所有人都进去;
    {
        p = Q.top();
        Q.pop();
        strcpy(ans[k++], p.Name);
    }
}

int main()
{
    int T;

    scanf("%d", &T);

    while(T--)
    {
        scanf("%d %d %d", &n, &m, &q);
        for(int i=1; i<=n; i++)
        {
            scanf("%s %d", a[i].Name, &a[i].v);
            a[i].Time = i;
        }

        for(int i=1; i<=m; i++)
            scanf("%d %d", &b[i].t, &b[i].cnt);

        sort(b+1, b+m+1);

        solve();

        for(int i=1; i<=q; i++)
        {
            int x;
            scanf("%d", &x);
            printf("%s%c", ans[x], i==q?\n: );
        }
    }
    return 0;
}
View Code

 

Alisha’s Party---hdu5437(模拟+优先队列)

标签:

原文地址:http://www.cnblogs.com/zhengguiping--9876/p/5734880.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!