/*CSCAN调度*/
#include <stdio.h>
#include <math.h>
#define N 100
#define MAX 10001
typedef struct Pro{
float aim;
float change;
bool loc;
}Pro;
Pro P[N];
void InputData(Pro a[],int n){
for(int i=0;i<n;i++){
printf("第%d进程位置",i+1);
scanf("%f",&a[i].aim);
a[i].loc=false;
}
}
float OutPutFinal(Pro a[],int n){
float sum=0;
for(int i=0;i<n;i++){
sum=sum+a[i].change;
}
return sum/n;
}
void Print(Pro a[],int i){
printf(" %d %3.0f %3.0f\n",i+1,a[i].aim,a[i].change);
}
int FindAim(Pro a[],int n,float location){
for(int i=0;i<n;i++){
if(a[i].aim>=location){
return i;
}
}
CSCAN调度算法(C语言描述)磁盘
最新推荐文章于 2021-05-24 16:47:49 发布
该博客详细介绍了CSCAN(Circular Scan)磁盘调度算法,并提供了C语言实现。首先,博主讲解了算法的基本原理,然后通过输入进程的个数和起始位置,对进程进行排序并计算每个进程的目标位置和改变位置。最后,博主展示了算法运行的输出结果,计算并输出了平均移动距离。
摘要由CSDN通过智能技术生成