pat1014 Waiting in Line

記錄一下這個隊列操作

思路:有多少個窗口就開多少個隊列,一個隊列和poptime、endtime組成一個新的數據類型,poptime代表對首出隊列的時間,endtime代表隊尾人結束時間。每次循環找出poptime最短的,打表記錄這個點結束的時間,最後查表就行了。

#include<iostream>
#include<string>
#include<algorithm>
#include<cstdio>
#include<vector>
#include<queue>
using namespace std;
struct node{
	int poptime,endtime;
	queue<int> q;
};
int main(){
	int n,m,k,q,index = 1;
	cin >> n >> m >> k >> q;
	vector<int> time(k + 1),result(k + 1);
	for(int i = 1;i <= k;i++){
		cin >> time[i];
	}
	vector<node> window(n + 1);
	vector<bool> sorry(k + 1,false);
	for(int i = 1;i <= m;i++){
		for(int j = 1;j <= n;j++){
			if(index <= k){
				window[j].q.push(time[index]);
				if(window[j].endtime >= 540)
				sorry[index] = true;
				window[j].endtime += time[index];
				if(i == 1)
				window[j].poptime = window[j].endtime;
				result[index] = window[j].endtime;
				index++;
			}
		}
	}
	while(index <= k){
		int tempmin = window[1].poptime,tempwindow = 1;
		for(int i = 2;i <= n;i++){
			if(window[i].poptime < tempmin){
				tempwindow = i;
				tempmin = window[i].poptime;
			}
		}
		window[tempwindow].q.pop();
		window[tempwindow].q.push(time[index]);
		window[tempwindow].poptime += window[tempwindow].q.front();
		if(window[tempwindow].endtime >= 540)
		sorry[index] = true;
		window[tempwindow].endtime += time[index];
		result[index] = window[tempwindow].endtime;
		index++;
	}
	for(int i = 1;i <= q;i++){
		int query,minute;
		cin >> query;
		minute = result[query];
		if(sorry[query] == true){
			printf("Sorry\n");
		}else{
			printf("%02d:%02d\n",(minute + 480) / 60,(minute + 480) % 60);
		}
	}
	return 0; 
} 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章