题意:模拟客服MM,一共有N种话题,每个客服MM支持处理其中的i个(i < N),处理的话题还有优先级。为了简化流程方便出题,设每个话题都是每隔m分钟来咨询一次。现知道每个话题前来咨询的时间、间隔、处理此话题所需的时长与一共有多少次咨询。问多少时间后全部话题处理完成。


代码:(Accepted,0.010s)

//UVa822 - Queue and A
//Accepted 0.010s
//#define _XIENAOBAN_
#include<algorithm>
#include<iostream>
#include<vector>
#include<queue>
#include<map>
#define MI 2147483647
using namespace std; struct T {
int ti; //time for per task
queue<int> table;
} ttmp;
struct P {
int id, at, st, n, to[22];//identity, available time, start time of last task, number of topics, topics
bool operator< (const P& that) const {
if (st != that.st) return st < that.st;
return id < that.id;
}
} ptmp; int Tpc, Psnl;//Number of Topics & Personnel
int name, num, nt, to, Scenario(0); int main()
{
#ifdef _XIENAOBAN_
#define gets(T) gets_s(T, 80)
freopen("in.txt", "r", stdin);
#endif
ptmp.at = 0;
while (scanf("%d", &Tpc) != EOF && Tpc != 0) {
int time(MI), needtime(0);
map<int, T> tpc;
for (int i(0);i < Tpc;++i) {
scanf("%d%d%d%d%d", &name, &num, &nt, &ttmp.ti, &to);
if (time > nt) time = nt;
auto& now(tpc[name] = ttmp);
for (int i(0);i < num;++i)
now.table.push(nt), nt += to;
}
scanf("%d", &Psnl);
vector<P> psnl(Psnl);
for (int i(0);i < Psnl;++i) {
scanf("%d%d", &ptmp.id, &ptmp.n);
for (int j(0);j < ptmp.n;++j)
scanf("%d", ptmp.to + j);
psnl[i] = ptmp;
}
while (Tpc) {
int jumpt = MI;//Jump time to the earliest possible available time of all the men
sort(psnl.begin(), psnl.end());
for (auto& p : psnl) {//For all staff members
int pti(MI);//Man's earliest possible available time
if (p.at > time) pti = p.at;//Man is busy
else { //Man is available
for (int i(0);i < p.n;++i) {//For all topics that man can handle
auto& t(tpc[p.to[i]]);
if (t.table.empty()) continue; //Man find current topic finished
if (t.table.front() <= time) { //Man find his topic
pti = time + t.ti;
if (needtime < pti) needtime = pti;
p.st = time;
t.table.pop();
if (t.table.empty()) --Tpc;
break;
}
else if (t.table.front() < pti) pti = t.table.front(); //Man find current topic will be available at t.table.front()
}
p.at = pti;
}
if (pti < jumpt) jumpt = pti;
}
time = jumpt;
}
printf("Scenario %d: All requests are serviced within %d minutes.\n", ++Scenario, needtime);
}
return 0;
}

分析:每分钟每分钟的模拟的话就有点慢了。我的做法是:

对每个topic,把它们每次过来询问的时间放在queue里,每开始处理一件就pop一件,直到它empty则说明处理完毕。

对每个员工,找出他的下一次“开始空闲”或“可能有事情做”的时间pti。所谓“开始空闲”或“可能有事情做”的时间是指:

  1. 若这人正在处理一个topic,则pti=处理完本topic的时间,这叫“开始空闲”;
  2. 若这人闲着,则给他找活干,若找到了可处理topic,pti=处理完这个topic的时间,也是“开始空闲”;
  3. 若这人闲着,但发现无活可干,每个他可以处理的topic都还没到来,那么他的pti=最快到来的下一个topic的时间,即只有topic来了他才可能“可能有事情做”。之所以是“可能”,因为每次都要按照“上一次开始干活的时间与ID”把每个人排序,所以他的活可能被抢,依然是“无事可干”状态。
  4. pti初始化时为int的最大值。只有当该员工的每个topic全都处理完的状态时,pti全程没有被赋值,于是该员工的下一个空闲时间变成无限大,一定程度上相当于以后的模拟运算就不考虑他了。

找出了每个人的pti,让时间跳转到最近的一个pti,进行下一次循环(要注意的是time最终跳出循环时可能不等于所需时间,所以又定义了个needtime)。

这题最坑的是,udebug的算法是错误的(⊙﹏⊙)。它的数据答案我死活对不上,害的我调试了好几天。。。后来去网上找别人的算法,发现结果和udebug也一大半数据对不上。但是提交后就AC了。(这uva的数据也比较水,udebug上的100个测试数据我运算了蛮慢的,但提交上去就0.010s。不过开心的是我的运算比网上找的那几个算法都快。)

[刷题]算法竞赛入门经典(第2版) 5-13/UVa822 - Queue and A的更多相关文章

  1. [刷题]算法竞赛入门经典(第2版) 5-7/UVa12100 - Printer Queue

    题意:一堆文件但只有一个打印机,按优先级与排队顺序进行打印.也就是在一个可以插队的的队列里,问你何时可以打印到.至于这个插队啊,题目说"Of course, those annoying t ...

  2. [刷题]算法竞赛入门经典(第2版) 4-6/UVa508 - Morse Mismatches

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,10 ms) //UVa508 - Morse Mismatches #include< ...

  3. [刷题]算法竞赛入门经典(第2版) 5-15/UVa12333 - Revenge of Fibonacci

    题意:在前100000个Fibonacci(以下简称F)数字里,能否在这100000个F里找出以某些数字作为开头的F.要求找出下标最小的.没找到输出-1. 代码:(Accepted,0.250s) / ...

  4. [刷题]算法竞赛入门经典(第2版) 4-5/UVa1590 - IP Networks

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,0 ms) //UVa1590 - IP Networks #include<iost ...

  5. [刷题]算法竞赛入门经典(第2版) 6-7/UVa804 - Petri Net Simulation

    题意:模拟Petri网的执行.虽然没听说过Petri网,但是题目描述的很清晰. 代码:(Accepted,0.210s) //UVa804 - Petri Net Simulation //Accep ...

  6. [刷题]算法竞赛入门经典(第2版) 6-6/UVa12166 - Equilibrium Mobile

    题意:二叉树代表使得平衡天平,修改最少值使之平衡. 代码:(Accepted,0.030s) //UVa12166 - Equilibrium Mobile //Accepted 0.030s //# ...

  7. [刷题]算法竞赛入门经典(第2版) 6-1/UVa673 6-2/UVa712 6-3/UVa536

    这三题比较简单,只放代码了. 题目:6-1 UVa673 - Parentheses Balance //UVa673 - Parentheses Balance //Accepted 0.000s ...

  8. [刷题]算法竞赛入门经典(第2版) 5-16/UVa212 - Use of Hospital Facilities

    题意:模拟患者做手术. 其条件为:医院有Nop个手术室.准备手术室要Mop分钟,另有Nre个恢复用的床.准备每张床要Mre分钟,早上Ts点整医院开张,从手术室手术完毕转移到回复床要Mtr分钟.现在医院 ...

  9. [刷题]算法竞赛入门经典(第2版) 5-11/UVa12504 - Updating a Dictionary

    题意:对比新老字典的区别:内容多了.少了还是修改了. 代码:(Accepted,0.000s) //UVa12504 - Updating a Dictionary //#define _XieNao ...

随机推荐

  1. Webpack 速成

    前言 如果你已经对Webpack精通了或者至少一直在工作中使用它,请关闭当前浏览器标签,无视这篇文章. 这篇文章本意是写给我自己看的,作为一篇Cookbook供快速查询和上手用.原因是虽然工作中会涉及 ...

  2. PHP开发人员对JAVA的WEB开发入门(初版-已废弃)

    最近准备对其他部门PHP开发的童鞋做一个对JAVA的培训.知己知彼,百战不殆,我要先了解点PHP,才能确认他们的基础,达到好的授课效果. PHP(原始为Personal Home Page的缩写,后正 ...

  3. 一个关于Python正则表达式的快速使用手册

    一直在纠结自己的博客到底应该写一些什么东西,这几天发现自己的正则用的不是很熟练,于是想要写一篇关于正则表达式的博客,目的就是为了让自己以后要用而又不会的时候不至于像无头苍蝇一样到处乱撞. 有些人在碰到 ...

  4. pl sql 查询显示乱码解决方法——设置环境变量NLS_LANG

    用oracle进行查询的时候,有的时候会出现查询结果为乱码的情况,此时要设置一个环境变量NLS_LANG. 此变量的值如何获得呢?运行下面sql语句就可以获得: select userenv('lan ...

  5. 设计模式(四)—观察者模式

    一.概述      观察者模式类似于邮件订阅和RSS订阅,当我们浏览一些博客或wiki时,经常会看到RSS图标,就这的意思是,当你订阅了该文章,如果后续有更新,会及时通知你.其实,简单来讲就一句话:当 ...

  6. Java 9 尝鲜之JShell交互式编程环境

    JShell--Java 9 的交互式编程环境 本文要求读者有基本的 Java 知识. Tips Java 9 的代码由于提供了新特性,所以有些代码并不支持向后兼容.也就是说,用 Java 9 写的代 ...

  7. JavaScript引用是如何工作的

    原文链接:https://www.sitepoint.com/how-javascript-references-work/ 摘要:JavaScript中没有指针,并且JavaScript中的引用与我 ...

  8. 图文详解linux如何搭建lamp服务环境

    企业网站建设必然离不开服务器运维,一个稳定高效的服务器环境是保证网站正常运行的重要前提.本文小编将会详细讲解Linux系统上如何搭建配置高效的lamp服务环境,并在lamp环境中搭建起企业自己的网站. ...

  9. mybatis面向接口的编程

    一.实现面向接口编程 具体操作方法如下: 第一:编写一个接口(IUser.java) 接口暂时为空接口,接口文件包路径:com.gusi.demo.idao.IUser 第二:修改映射文件(User. ...

  10. 深入解析Hashtable、Dictionary、SortedDictionary、SortedList

    我们先看Hashtable. MSDN的解释:表示键/值对的集合,这些键/值对根据键的哈希代码进行组织. Hash算法是把任意长度的输入(又叫做预映射, pre-image),通过散列算法,变换成固定 ...