网站首页 全球最实用的IT互联网站!

人工智能P2P分享Wind搜索发布信息网站地图标签大全

当前位置:诺佳网 > 软件工程 > 后端开发 > C++ >

比赛题解 总结

时间:2025-10-23 21:21

人气:

作者:admin

标签:

导读:1.[HNOI2003] 操作系统 思路 此题是一道大模拟,主要根据任务优先级来计算最后执行此任务的时间,此时我们可以进行分类讨论: 当此任务的到达时间晚于等于上一个未执行完任务的结束...

思路

此题是一道大模拟,主要根据任务优先级来计算最后执行此任务的时间,此时我们可以进行分类讨论:

  • 当此任务的到达时间晚于等于上一个未执行完任务的结束时间,上一个任务就一定能运行完,因此直接输出结束时间
  • 当此任务的到达时间早于上一个未执行完任务的结束时间,上一个任务就只能在 CPU 中运行一段时间,因此只能更新执行时间
    因为执行任务要看其优先级,因此我们用优先队列来存所有进入过 CPU 但还未运行完的任务,然后根据其优先级排序。

注意

我们需要用个变量 lati 来存总时间,因此本文中的上一个 "上一个未执行完任务的结束时间" 是指 lati + 上个任务的执行时间

AC代码

点开有惊喜
#include<bits/stdc++.h>
#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<a.yx;
	}
}a;
ll lati;
priority_queue<node> 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<=a.be){
			node b=q.top();
			q.pop();
			cout<<b.id<<" "<<lati+b.ti<<"\n";
			lati+=b.ti;
		}
		if(q.size()){
			node b=q.top();
			q.pop();
			b.ti-=a.be-lati;
			q.push(b);
		}
		q.push(a);
		lati=a.be;
	}
	while(q.size()){
		node b=q.top();
		q.pop();
		lati+=b.ti;
		cout<<b.id<<" "<<lati<<"\n";
	}
	return 0;
}
温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信