【算法】C++实现短作业优先算法

本文介绍了短作业优先(SJF)调度算法,该算法以服务时间最短的作业优先得到服务,旨在减少平均等待时间。文章还提到了其抢占式版本——最短剩余时间优先(SRTN),并指出这种算法可能导致长作业的饥饿现象。随后,提供了C++代码实现。
摘要由CSDN通过智能技术生成

一、说明

作业/进程调度算法 – 短作业优先算法

  1. 算法思想:追求最少的平均等待时间,最少的平均周转时间、最少的平均带权周转时间。
  2. 算法规则: 服务时间最短的作业/进程优先得到服务。
  3. 抢占式版本:最短剩余时间优先算法(SRTN)
  4. 缺点:对短作业有利,对长作业不利。如果源源不断地有短作业/进程到来,可能使长作业/进程长时间得不到服务,产生“饥饿”现象。

二、代码

#include <string>
#include <algorithm>
#include <iostream>
#include <iomanip>
using namespace std;

// 就绪队列最大长度
const int MAX = 100;
// 就绪态
#define W "waitting"
// 运行态
#define R "running"
// 完成态
#define F "finished"

struct WORK
{
   
	// 进程名称
	string work_name;
	// 到达时间
	int arrive_time;
	// 剩余服务时间
	int serve_time;
	// 服务时间
	int r_serve_time;
	// 进程状态
	string work_state;
	// 结束时间
	int end_time;
	// 周转时间
	int turnover_time;
};

// 就绪队列
WORK work[MAX]; 
// 进程数量
int n; 


void init() {
   
	cout << "请输入需要调度的进程数: ";
	cin >> n;
	for (int i = 1; i <= n; ++i) {
   
		cout << "请输入进程" << i << "的名称、到达时间、服务时间: ";
		cin >> work[i].work_name >> work[i].arrive_time >> work[i].r_serve_time;
		// 进程状态
		work[i].work_state = W;
		// 结束时间
		work[i].end_time = -1;
		// 剩余服务时间
		work[i].serve_time = work
#include //定义一个结构体 struct sjf{ char name[10]; //进程名 float arrivetime; //到达时间 float servicetime;//服务时间 float starttime; //开始时间 float finishtime;//完成时间 float zztime;//周转时间 float dqzztime;//带权周转 }; //定义一个结构体数组 sjf a[100]; //定义一个输入函数 void input(sjf *p,int N) { int i; printf("intput the process's name & arrivetime & servicetime:\nfor exmple: a 0 100\n"); for(i=0;i<=N-1;i++) { printf("input the %dth process's information:\n",i+1); scanf("%s%f%f",&p[i].name,&p[i].arrivetime,&p[i].servicetime); } } //定义一个输出函数 void Print(sjf *p,float arrivetime,float servicetime,float starttime,float finishtime,float zztime,float dqzztime,int N) { int k; printf("run order:");//执行顺序 printf("%s",p[0].name); for(k=1;k%s",p[k].name); } printf("\nthe process's information:\n"); printf("\nname\tarrive\tservice\tstart\tfinish\tzz\tdqzz\n"); for(k=0;k<=N-1;k++) { printf("%s\t%-.2f\t%-.2f\t%-.2f\t%-.2f\t%-.2f\t%-.2f\t\n",p[k].name,p[k].arrivetime,p[k].servicetime,p[k].starttime,p[k].finishtime,p[k].zztime,p[k].dqzztime); } } //按到达时间排序 void sort(sjf *p,int N) { for(int i=0;i<=N-1;i++) for(int j=0;j<=i;j++) if(p[i].arrivetime<p[j].arrivetime) { sjf temp; temp=p[i]; p[i]=p[j]; p[j]=temp; } } //运行阶段 void deal(sjf *p, float arrivetime,float servicetime,float starttime,float finishtime,float &zztime,float &dqzztime,int N) { int k; for(k=0;k=p[k].arrivetime) { p[k].starttime=p[k-1].finishtime;} else { p[k].starttime =p[k].arrivetime;} p[k].finishtime=p[k].starttime+p[k].servicetime; } } for(k=0;k<=N-1;k++) { p[k].zztime=p[k].finishtime-p[k].arrivetime;//周转时间=完成时间-到达时间 p[k].dqzztime=p[k].zzti
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值