HRBUST 1313 火影忍者之~静音

优先队列。

每次将$n$个人压入优先队列,取出$5$个,最后排序。

#include
#include
#include
#include
#include
#include<set>
#include
#include
#include
#include
using namespace std;

int m,n;
struct X
{
    string name;
    int A,B;

    X(string Name,int AA,int BB)
    {
        name = Name;
        A=AA;
        B=BB;
    }

    bool operator < (const X &a) const {
        if(A!=a.A) return A<a.A;
        return name>a.name;
    }
};

struct Y
{
    string name;
    int A,B;
}t[10010];

bool cmp2(Y a,Y b)
{
    if(a.B!=b.B) return a.B>b.B;
    return a.name<b.name;
}

int main()
{
    while(~scanf("%d%d",&m,&n))
    {
        priority_queueQ;
        int sz=0;
        for(int i=0;i)
        {
            for(int j=0;j)
            {
                string str; int AA,BB;
                cin>>str;
                scanf("%d",&AA);
                scanf("%d",&BB);
                Q.push(X(str,AA,BB));
            }

            for(int j=0;j<5;j++)
            {
                X TOP = Q.top(); Q.pop();
                t[sz].name = TOP.name;
                t[sz].A = TOP.A;
                t[sz].B = TOP.B;

                sz++;
            }
        }

        sort(t,t+5*m,cmp2);
        for(int i=0;i<5;i++) cout<endl;

    }
    return 0;
}

 

转载于:https://www.cnblogs.com/zufezzt/p/6518720.html

你可能感兴趣的:(HRBUST 1313 火影忍者之~静音)