操作系统实验--SSTF磁盘调度算法

Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^

题目描述

磁盘调度在多道程序设计的计算机系统中,各个进程可能会不断提出不同的 对磁盘进行读/写操作的请求。由于有时候这些进程的发送请求的速度比磁盘响应的还要快,因此我们有必要为每个磁盘设备建立一个等待队列,最短寻道时间优先 算法(Shortest Seek Time First-SSTF)是常用的磁盘调度算法之一。

SSTF算法选择调度处理的磁道是与当前磁头所在磁道距离最近的磁道,以使每次的寻找时间最短。当然,总是选择最小寻找时间并不能保证平均寻找时间最小,但是能提供比FCFS算法更好的性能。这种算法会产生“饥饿”现象。

1、算法思想:优先选择距当前磁头最近的访问请求进行服务,主要考虑寻道优先。

2、优点:改善了磁盘平均服务时间。

3、缺点:造成某些访问请求长期等待得不到服务。

对于给定的磁头所在的当前磁道号和请求访问的磁道号队列(FIFO),试设计一个解此问题的算法,计算磁道访问序列和平均寻道长度(保留两位小数),并分析算法的正确性与计算复杂性。

输入

多组输入。输入数据的第一行是正整数n(0 < n < 500),表示磁头所在的当前磁道号;第2 行是正整数m(8 ≤ n ≤ 20),表示请求访问的磁道号队列长度;第三行有m个正整数ai(0 < a­I < 500),表示请求访问队列的m个磁道号。

输出

输出m+1行,前m行每行有两个整数,分别表示磁道号和移动的磁道数,第m+1行表示计算出的平均寻道长度(保留两位小数)。

示例输入

100 9
350
180
22
365
30
120
185
60
200

示例输出

120 20
180 60
185 5
200 15
60 140
30 30
22 8
350 328
365 15
69.00 算法思路:每次都要找距离当前磁头所在磁道最近的一条需要访问的磁道进行访问。如果当前有2条甚至多条磁道但距离当前所在磁道
距离均相同呢?按照磁道序列的优先级,进行寻道!
代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <ctype.h>
#include <math.h>
#include <algorithm>
#define eps 1e-8 using namespace std; struct node
{
int num;
int pri;
bool operator <(const node &dd)const{
return num<dd.num;
}
};
int main()
{
int n, m;
int i, j; node a[600]; while(scanf("%d %d", &n, &m)!=EOF)
{
for(i=0; i<m; i++){
scanf("%d", &a[i].num);
a[i].pri=m-i;
}
a[m].num=n; a[m].pri=0; int pos;
sort(a, a+m+1); int sum=0, cur;
for(i=0; i<=m; i++){
if(a[i].num ==n) pos=i;
}
cur=a[pos].num; i=pos-1; j=pos+1;
int dd, ff;
while(i>=0 && j<=m )
{
dd=cur-a[i].num;
ff=a[j].num-cur;
if(ff<dd){
printf("%d %d\n", a[j].num, ff);
sum+=ff;
cur=a[j].num;
j++;
}
else if(ff>dd){
printf("%d %d\n", a[i].num, dd);
sum+=dd;
cur=a[i].num;
i--;
}
else{
if(a[j].pri>a[i].pri){
printf("%d %d\n", a[j].num, a[j].num-cur );
sum+=(a[j].num-cur);
cur=a[j].num;
j++;
}
else{
printf("%d %d\n", a[i].num, cur-a[i].num);
sum+=(cur-a[i].num);
cur=a[i].num;
i--;
}
}
}
while(i<0 && j<=m){
printf("%d %d\n", a[j].num, a[j].num-cur);
sum+=(a[j].num-cur);
cur=a[j].num;
j++;
}
while(j>m && i>=0)
{
printf("%d %d\n", a[i].num, cur-a[i].num);
sum+=(cur-a[i].num);
cur=a[i].num;
i--;
}
//printf("i==%d j==%d\n", i, j);
double ans=(double)sum/m;
printf("%.2lf\n", ans); }
return 0;
}

sdut oj 操作系统实验--SSTF磁盘调度算法【操作系统算法】的更多相关文章

  1. SDUT OJ 数据结构实验之图论十:判断给定图是否存在合法拓扑序列

    数据结构实验之图论十:判断给定图是否存在合法拓扑序列 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Prob ...

  2. SDUT OJ 数据结构实验之图论八:欧拉回路

    数据结构实验之图论八:欧拉回路 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descrip ...

  3. SDUT OJ 数据结构实验之图论六:村村通公路(最小生成树)

    数据结构实验之图论六:村村通公路 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descri ...

  4. SDUT OJ 数据结构实验之图论五:从起始点到目标点的最短步数(BFS)

    数据结构实验之图论五:从起始点到目标点的最短步数(BFS) Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss P ...

  5. SDUT OJ 数据结构实验之图论四:迷宫探索

    数据结构实验之图论四:迷宫探索 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descrip ...

  6. SDUT OJ 数据结构实验之二叉树八:(中序后序)求二叉树的深度

    数据结构实验之二叉树八:(中序后序)求二叉树的深度 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Probl ...

  7. SDUT OJ 数据结构实验之二叉树七:叶子问题

    数据结构实验之二叉树七:叶子问题 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descri ...

  8. SDUT OJ 数据结构实验之二叉树六:哈夫曼编码

    数据结构实验之二叉树六:哈夫曼编码 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descr ...

  9. SDUT OJ 数据结构实验之二叉树五:层序遍历

    数据结构实验之二叉树五:层序遍历 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descri ...

随机推荐

  1. C++ Primer(第五版)读书笔记 & 习题解答 --- Chapter 1

    Chapter 1.1 1. 每个C++程序都必须有且只能有一个main函数,main函数的返回类型必须是int.操作系统通过调用main函数来运行C++程序. 2. 一个函数的定义包含四部分:返回类 ...

  2. oracle中提高order by的性能

    1.如果order by columnA,那么在where查询条件中添加条件columnA=value,则oracle内部会过滤order by排序,直接用索引(可以通过execution plan查 ...

  3. which 命令

    我们经常在linux要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索:        which  查看可执行文件的位置.       whereis 查看文件的位置.         ...

  4. UML类图中的关系表示

    UML类图中的关系和表示方法 类图是用来描述程序中的类以及它们之间的关系的,使用类图可以帮助我们简化对系统的理解.在UML类图中比较常见的关系有六种,它们分别是:依赖.关联.聚合.组合.泛化.实现,这 ...

  5. ps -ef 和 aux 区别

    Linux中的ps命令是Process Status的缩写.ps命令用来列出系统中当前运行的那些进程.ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信 ...

  6. SPSS统计功能与模块对照表

    SPSS统计功能 - 应用速查表第一列为统计方法,中间为统计功能,最后一列为所在模块 1 ANOVA Models(单因素方差分析:简单因子) : 摘要 描述 方差 轮廓 - SPSS Base 2 ...

  7. 三种光照模型的shader实现

    1.Lambert模型,公式为I=Kd*Il(N*L): Shader "Custom/Lambert_A" { Properties { _Diffuse(,,,) } SubS ...

  8. hdu 5881 Tea (2016 acm 青岛网络赛)

    原题地址:http://acm.hdu.edu.cn/showproblem.php?pid=5881 Tea Time Limit: 3000/1000 MS (Java/Others)    Me ...

  9. html5-补充知识

    原理 html5+开发app的原理大概是这样: html页面负责内容: ui负责页面样式: js负责调用原生app方法. html5 html5这部分负责页面,也就是app中你看到的东西,大概的架构和 ...

  10. 调整虚拟机中Linux的分辨率

    1 在虚拟机配置中,将显示的缓存提高,CPU也提高. 2 运行Linux,在system-preferences-display中调整分辨率