首页 > 代码库 > hdu1434 优先队列
hdu1434 优先队列
#include<stdio.h> #include<string.h> #include<queue> #include<iostream> using namespace std; struct node { char name[25]; int rp; bool operator < (const node& x) const { return rp>x.rp||(rp==x.rp&&strcmp(name,x.name)<0); } }a,b; int main() { int n,m,i,j,k,l,cont; char str[25],rp; while(~scanf("%d%d",&n,&m)) { priority_queue<node>q[10010]; for(i=1;i<=n;i++) { scanf("%d",&cont); while(cont--) { scanf("%s%d",a.name,&a.rp); //strcpy(a.name,str); //a.rp=rp; q[i].push(a); } } for(i=1;i<=m;i++) { scanf("%s",str); if(str[0]==‘G‘&&str[4]==‘N‘) { scanf("%d%s%d",&k,a.name,&a.rp); q[k].push(a); } else if(str[0]==‘J‘) { scanf("%d%d",&k,&l); while(!q[l].empty()) { b=q[l].top(); q[l].pop(); q[k].push(b); } } else { scanf("%d",&k); b=q[k].top(); q[k].pop(); printf("%s\n",b.name); } } } return 0; }
hdu1434 优先队列
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。