一,算法代码

#include<stdio.h>struct sjf { //定义进程的结构体    char name[10];//进程名    float arrivetime;//到达时间    float servicetime;//服务时间    float starttime;//开始时间    float finishtime;//完成时间    float zztime; //周转时间    float dqzztime;//带权周转时间};struct sjf b[100];//定义短作业优先算法进程的最大数量void Sinput(struct sjf *p,int N) { //输入函数    int i;    printf("输入进程的名称、到达时间、服务时间:(例如   : x 0 100)\n");    for(i=0; i<=N-1; i++) {        printf("输入第%d进程的名称、到达时间、服务时间:",i+1);        scanf("%s%f%f",&p[i].name,&p[i].arrivetime,&p[i].servicetime);    }}//输出函数void SPrint( struct sjf *p,float arrivetime,float servicetime,             float starttime,float finishtime,float zztime,float dqzztime,int N) {    int k;    printf("\n执行顺序:\n");    printf("%s",p[0].name);    for(k=1; k<N; k++) {        printf("-%s",p[k].name);    }    printf("\n进程名\tarrive\tservice\tstart\tfinish\tzhouzhuan\tdaiquanzz\n");    for(k=0; k<=N-1; k++) {        printf("%s\t%-.2f\t%-.2f\t%-.2f\t%-.2f\t%-.2f\t%-.2f\t\n\n",        p[k].name,p[k].arrivetime,p[k].servicetime,p[k].starttime,p[k].finishtime,        p[k].zztime,p[k].dqzztime);    }    printf("\n");    }     void Ssort(struct sjf *p,int N)     { //按短作业优先算法排序        int i,j;        for( i=1; i<=N-1; i++)            for( j=1; j<=i; j++)                if(p[i].servicetime<p[j].servicetime) {                    struct sjf temp;                    temp=p[i];                    p[i]=p[j];                    p[j]=temp;                }    }//运行结果    void Sdeal(struct sjf *p,float arrivetime,float servicetime,    float starttime,float finishtime,float zztime,float dqzztime,int N)    {        int k;        for(k=0; k<=N-1; k++) {            if(k==0) {                p[k].starttime=p[k].arrivetime;                p[k].finishtime=p[k].arrivetime+p[k].servicetime;            } else {                p[k].starttime=p[k-1].finishtime;                //开始时间 =    前一个进程的完成时间                p[k].finishtime=p[k-1].finishtime+p[k].servicetime;                //结束时间=前一个进程的完成时间  + 现在进程的服务时间            }        }    for(k=0; k<=N-1; k++) {        p[k].zztime=p[k].finishtime-p[k].arrivetime;        //  周转时间 =完成时间 -到达时间        p[k].dqzztime=p[k].zztime/p[k].servicetime;        //带权周转时间=周转时间 /服务时间    }}void SJF(struct sjf *p,int N){    float arrivetime=0,servicetime=0,starttime=0,    finishtime=0,zztime=0,dqzztime=0;    Ssort(p,N);    Sdeal(p,arrivetime,servicetime,starttime,finishtime,zztime,dqzztime,N);    SPrint(p,arrivetime,servicetime,starttime,finishtime,zztime,dqzztime,N);}void main() { //主函数    int M;    printf("-----------短作业优先调度算法-----------\n");    printf("输入进程数:");    scanf("%d",&M);    Sinput(b,M);    SJF(b,M);}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113

二,算法截图

本算法转自:https://wenku.baidu.com/view/c38baaf3fad6195f302ba668.html

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

操作系统短作业优先(SJF)调度算法相关推荐

  1. 【操作系统 - 1】先来先服务FCFS和短作业优先SJF进程调度算法

    操作系统系列 学习至此,发现很多学了但很久没用的知识,久而久之,慢慢遗忘.等哪天还需要的话,却发现已经忘得差不多了,即使整理了文档(word等),还是得从头再学一遍.读研第一学期,发现很多东西都可以从 ...

  2. 《操作系统》实验一:先来先服务FCFS和短作业优先SJF进程调度算法

    [实验题目]:先来先服务FCFS和短作业优先SJF进程调度算法 [实验学时]:4学时 [实验目的] 通过这次实验,加深对进程概念的理解,进一步掌握进程状态的转变.进程调度的策略及对系统性能的评价方法. ...

  3. 作业调度算法【平均周转时间、平均带权周转时间、先来先服务FCFS、短作业优先SJF、高优先权(级)算法FPF、高响应比优先算法HRRN】

    文章目录 先来先服务算法(FCFS) 短作业优先算法(SJF).短进程优先算法(SPF) 周转时间和带权周转时间 高优先权(级)调度算法FPF 高响应比优先调度算法HRRN 先来先服务算法(FCFS) ...

  4. 调度算法——先来先服务(FCFS)、短作业优先(SJF)、高响应比优先(HRRN) 例题详细!!!

    文章目录 前言 知识总览 先来先服务(FCFS, First Come First Serve) 短作业优先(SJF, Shortest Job First) 对FCFS和SJF两种算法的思考 高响应 ...

  5. 【学习笔记】第二章——调度算法:先来先服务FCFS、短作业优先SJF、高响应比HRRN

    文章目录 一. 先来先服务(FCFS) 二. 短作业优先(SJF) 三. 高响应比优先 1. 对前面两种算法的思考 2. 描述 四. 一.二.三总结 例子都要手动写一遍哦-这三个是供早期的批处理系统使 ...

  6. 操作系统短作业优先(SJF)算法

    短作业优先(SJF)算法 SJF概念 以运行作业的时间长短来决定计算的优先级,作业运行时间越短,优先级越高. SJF算法展示(java) 首先我们先来创建一个Process类来模拟作业 package ...

  7. 短作业优先算法c语言实现,OS短作业优先调度算法C语言

    OS短作业优先调度算法C语言 采用短作业优先调度算法调度程序 学 号: 姓 名: 专 业: 指导老师: 日 期: 目录 一.实验题目3 二.课程设计的目的3 三.设计内容3 四.设计要求3 五.主要数 ...

  8. 2.2.4 操作系统之作业/进程调度算法(FCFS先来先服务、SJF短作业优先、HRRN高响应比优先)

    文章目录 0.思维导图 1.先来先服务---FCFS 2.短作业优先---SJF 3.高响应比优先---HRRN 4.三种算法的对比和总结 0.思维导图 1.先来先服务-FCFS First come ...

  9. 操作系统:先来先服务调度算法以及短作业优先调度算法C语言实现

    FCFS(先来先服务)和SJF(短作业优先)调度算法 先来先服务(FCFS)调度算法是一种最简单的调度算法,该算法既可用于作业调度,也可用于进程调度.当在作业调度中采用该算法时,每次调度都是从后备作业 ...

最新文章

  1. no qualifying bean of type_就是要让你彻底学会 @Bean 注解
  2. java文本输入输出小结
  3. python 珠玑妙算
  4. linux 6.3 vnc安装包,CentOS 6.3安装和配置VNC
  5. Spark常用函数讲解之键值RDD转换
  6. mysql 索引及索引创建原则
  7. java spring mvc api_SpringMVC实现REST API
  8. 使用 Caddy 替代 Nginx,全站升级 https,配置更加简单
  9. 利用存储过程批量生成数据
  10. 【鸿蒙热】下的冷思考
  11. 推荐一个开源好用的ER图、流程图作图软件-draw.io
  12. winRAR 离购买许可只剩xx天
  13. latex引用图标出现问号
  14. 勾股定理的毕达哥拉斯证明
  15. c语言学习笔记(持续更新中)
  16. Linux使用详解(进阶篇)
  17. python有什么特点有什么应用方向_你知道吗?python特点+可以做什么+就业前景(附30G学习资料)...
  18. 路由器交换机存储部件浅析
  19. QT学习11:clicked和toggled信号
  20. android include闪退,运行闪退,怎么解决#includestdio.h#includestdlib【神奇海螺吧】_百度贴吧...

热门文章

  1. 一个自动生成关键字索引页面的比处理文件
  2. ASP.NET MVC3 系列教程 - 部署你的WEB应用到IIS 6.0
  3. Vue报错:Elements in iteration expect to have ‘v-bind:key‘ directives的解决办法
  4. mongodb [main] Automatically disabling TLS 1.0, to force-enable TLS 1.0 specify
  5. Arcgis10安装说明
  6. ug建模文本怎么竖着_入门到成为UG编程高手,这些步骤你不得不了解
  7. String类与其他数据类型得转换
  8. C++如何产生随机数
  9. java 字符过滤器_Java Web---登录验证和字符编码过滤器
  10. 实验7 寻址方式在结构化数据访问总的应用