非抢占式优先级调度算法c语言

时间: 2023-07-29 10:07:56 浏览: 30
下面是一个简单的非抢占式优先级调度算法的示例代码,使用C语言实现: ```c #include <stdio.h> #define MAX 5 struct process { int pid; int priority; int burst_time; int waiting_time; int turnaround_time; }; int main() { struct process p[MAX], temp; int i, j, n = 0; float avg_waiting_time = 0, avg_turnaround_time = 0; // 读入进程信息 printf("Enter the number of processes: "); scanf("%d", &n); for (i = 0; i < n; i++) { printf("Enter process %d details:\n", i+1); printf("PID: "); scanf("%d", &p[i].pid); printf("Priority: "); scanf("%d", &p[i].priority); printf("Burst Time: "); scanf("%d", &p[i].burst_time); } // 根据优先级排序 for (i = 0; i < n-1; i++) { for (j = i+1; j < n; j++) { if (p[i].priority > p[j].priority) { temp = p[i]; p[i] = p[j]; p[j] = temp; } } } // 计算等待时间和周转时间 p[0].waiting_time = 0; p[0].turnaround_time = p[0].burst_time; for (i = 1; i < n; i++) { p[i].waiting_time = p[i-1].waiting_time + p[i-1].burst_time; p[i].turnaround_time = p[i].waiting_time + p[i].burst_time; } // 计算平均等待时间和平均周转时间 for (i = 0; i < n; i++) { avg_waiting_time += p[i].waiting_time; avg_turnaround_time += p[i].turnaround_time; } avg_waiting_time /= n; avg_turnaround_time /= n; // 输出结果 printf("\nPID\tPriority\tBurst Time\tWaiting Time\tTurnaround Time\n"); for (i = 0; i < n; i++) { printf("%d\t%d\t\t%d\t\t%d\t\t%d\n", p[i].pid, p[i].priority, p[i].burst_time, p[i].waiting_time, p[i].turnaround_time); } printf("\nAverage Waiting Time: %.2f\n", avg_waiting_time); printf("Average Turnaround Time: %.2f\n", avg_turnaround_time); return 0; } ``` 该算法的基本思路是按照优先级对进程进行排序,然后依次执行优先级最高的进程。如果有多个进程具有相同的优先级,则按照先来先服务的原则依次执行。在执行每个进程时,需要计算它的等待时间和周转时间。最终,可以计算出所有进程的平均等待时间和平均周转时间。

相关推荐

最新推荐

recommend-type

非抢占式调度算法的实现(非抢占式、不可剥夺式)

非抢占式调度算法的实现(非抢占式、不可剥夺式) 时间如冲冲流水,一转眼间都毕业快一年了。这一年里忙忙碌碌,却又碌碌无为。有时又总想,生亦何苦,死亦何哀。之前做了个STM8的脱机编程器,使用了EMWIN,学习到了...
recommend-type

员工考勤系统.docx

员工考勤系统.docx
recommend-type

基于STM32的调试模块的外设和时钟电路分析

基于STM32的调试模块的外设和时钟电路分析。回顾 CMSIS、LL、HAL 库
recommend-type

基于 UDP 的分布式毫米波雷达python代码.zip

1.版本:matlab2014/2019a/2021a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
recommend-type

pyzmq-25.1.1b2-cp36-cp36m-musllinux_1_1_x86_64.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

优化MATLAB分段函数绘制:提升效率,绘制更快速

![优化MATLAB分段函数绘制:提升效率,绘制更快速](https://ucc.alicdn.com/pic/developer-ecology/666d2a4198c6409c9694db36397539c1.png?x-oss-process=image/resize,s_500,m_lfit) # 1. MATLAB分段函数绘制概述** 分段函数绘制是一种常用的技术,用于可视化不同区间内具有不同数学表达式的函数。在MATLAB中,分段函数可以通过使用if-else语句或switch-case语句来实现。 **绘制过程** MATLAB分段函数绘制的过程通常包括以下步骤: 1.
recommend-type

SDN如何实现简易防火墙

SDN可以通过控制器来实现简易防火墙。具体步骤如下: 1. 定义防火墙规则:在控制器上定义防火墙规则,例如禁止某些IP地址或端口访问,或者只允许来自特定IP地址或端口的流量通过。 2. 获取流量信息:SDN交换机会将流量信息发送给控制器。控制器可以根据防火墙规则对流量进行过滤。 3. 过滤流量:控制器根据防火墙规则对流量进行过滤,满足规则的流量可以通过,不满足规则的流量则被阻止。 4. 配置交换机:控制器根据防火墙规则配置交换机,只允许通过满足规则的流量,不满足规则的流量则被阻止。 需要注意的是,这种简易防火墙并不能完全保护网络安全,只能起到一定的防护作用,对于更严格的安全要求,需要
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。