POJ 3125 && Sicily 1443 Printer Queue(模拟/队列)

原文地址:http://blog.csdn.net/ChinaCzy/archive/2010/05/15/5594040.aspx //

//简单的队列模拟 #include<iostream> #include<queue> #include<cstring> #include<algorithm> using namespace std; int priority[101]; struct Job { int priority; bool yours; }job[101]; bool cmp(int a,int b) { return a > b; } int main() { //freopen("in.txt","r",stdin); int t; scanf("%d",&t); while(t--) { int n,p,time = 1,pt = 0; memset(job,0,sizeof(Job)*100); queue<Job> q; scanf("%d%d",&n,&p); job[p].yours = 1; for(int i = 0;i < n;++i) { scanf("%d",&priority[i]); job[i].priority = priority[i]; q.push(job[i]); } sort(priority,priority+n,cmp); while(q.front().priority != priority[pt] || !q.front().yours) //终止条件轮到目标元素打印且其优先级刚好最高 { Job temp; temp = q.front(); q.pop(); if(temp.priority == priority[pt]) { pt++; ++time; } else q.push(temp); } printf("%d/n",time); } return 0; }  

你可能感兴趣的:(struct,2010)