比赛题解 总结
1. 操作系统思路
此题是一道大模拟,主要根据任务优先级来计算最后执行此任务的时间,此时我们可以进行分类讨论:
[*]当此任务的到达时间晚于等于上一个未执行完任务的结束时间,上一个任务就一定能运行完,因此直接输出结束时间
[*]当此任务的到达时间早于上一个未执行完任务的结束时间,上一个任务就只能在 CPU 中运行一段时间,因此只能更新执行时间
因为执行任务要看其优先级,因此我们用优先队列来存所有进入过 CPU 但还未运行完的任务,然后根据其优先级排序。
注意
我们需要用个变量 lati 来存总时间,因此本文中的上一个 "上一个未执行完任务的结束时间" 是指 lati + 上个任务的执行时间
AC代码
点开有惊喜#include#define ll long long using namespace std;struct node{ ll id,be,ti,yx; bool operator < (const node &a)const{ if(yx==a.yx) return be>a.be; return yx q;int main(){ while(scanf("%lld%lld%lld%lld",&a.id,&a.be,&a.ti,&a.yx)!=EOF){ while(q.size()&&q.top().ti+lati 感谢发布原创作品,程序园因你更精彩 感谢,下载保存了 收藏一下 不知道什么时候能用到 感谢,下载保存了 这个好,看起来很实用 感谢,下载保存了 感谢,下载保存了 感谢分享,学习下。 鼓励转贴优秀软件安全工具和文档! 这个有用。 鼓励转贴优秀软件安全工具和文档! 这个有用。 鼓励转贴优秀软件安全工具和文档! 感谢发布原创作品,程序园因你更精彩 喜欢鼓捣这些软件,现在用得少,谢谢分享! 谢谢分享,试用一下 过来提前占个楼 喜欢鼓捣这些软件,现在用得少,谢谢分享! 前排留名,哈哈哈
页:
[1]
2