其实就是对于操作符进行重载,然后用个优先队列,水之。 还有先后顺序的优先级不要问了。
#include <iostream> #include <queue> #include <algorithm> #include <cstring> using namespace std; struct node { char name[1000]; int parameter; int priority; int num; //这里出错了。。。应该加个先后顺序排序。。。类似上次HDU做的队列里的一题, friend bool operator<(node a,node b) { if(b.priority == a.priority) return b.num < a.num; return b.priority < a.priority; } }; int main() { priority_queue <node> q; char str[100]; node temp; int num=0; while(~scanf("%s",str)) { if(strcmp(str,"GET")==0) { if(!q.empty()) { temp = q.top(); printf("%s %d\n",temp.name,temp.parameter); q.pop(); } else printf("EMPTY QUEUE!\n"); } else { scanf("%s %d %d",&temp.parameter,&temp.priority); temp.num=num++; q.push(temp); } } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。