sdut oj 操作系统实验--SSTF磁盘调度算法【操作系统算法】
操作系统实验--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 < aI < 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磁盘调度算法【操作系统算法】的更多相关文章
- SDUT OJ 数据结构实验之图论十:判断给定图是否存在合法拓扑序列
数据结构实验之图论十:判断给定图是否存在合法拓扑序列 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Prob ...
- SDUT OJ 数据结构实验之图论八:欧拉回路
数据结构实验之图论八:欧拉回路 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descrip ...
- SDUT OJ 数据结构实验之图论六:村村通公路(最小生成树)
数据结构实验之图论六:村村通公路 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descri ...
- SDUT OJ 数据结构实验之图论五:从起始点到目标点的最短步数(BFS)
数据结构实验之图论五:从起始点到目标点的最短步数(BFS) Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss P ...
- SDUT OJ 数据结构实验之图论四:迷宫探索
数据结构实验之图论四:迷宫探索 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descrip ...
- SDUT OJ 数据结构实验之二叉树八:(中序后序)求二叉树的深度
数据结构实验之二叉树八:(中序后序)求二叉树的深度 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Probl ...
- SDUT OJ 数据结构实验之二叉树七:叶子问题
数据结构实验之二叉树七:叶子问题 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descri ...
- SDUT OJ 数据结构实验之二叉树六:哈夫曼编码
数据结构实验之二叉树六:哈夫曼编码 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descr ...
- SDUT OJ 数据结构实验之二叉树五:层序遍历
数据结构实验之二叉树五:层序遍历 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descri ...
随机推荐
- smarty、smarty格式化、smarty整数、smarty float、smarty各种转换方式、smarty日期转换等等 (转)
<? require("setup.php"); define('PAGETITLE','pagtitle'); function insert_top($lid,$sid) ...
- 浅谈BloomFilter【上】基本概念和实现原理
在日常生活中.包括在设计计算机软件时,我们常常要推断一个元素是否在一个集合中. 比方在字处理软件中,须要检查一个英语单词是否拼写正确(也就是要推断 它是否在已知的字典中).在 FBI. ...
- Atitit.jdk java8的语法特性详解 attilax 总结
Atitit.jdk java8的语法特性详解 attilax 总结 1.1. 类型推断这个特别有趣的.鲜为人知的特性1 2. Lambda1 2.1. 内部迭代意味着改由Java类库来进行迭代,而不 ...
- Ubuntu14下Hadoop开发<1> 基础环境安装
准备了一台淘汰的笔记本.单核CPU.3G内存.160G硬盘:准备一个2G的U盘 在官网下载了64位的14.04版本号(麒麟)的ISO.下载UNetbootin(Ubuntu专用U盘安装工具) 使用UN ...
- Unable to resolve address ' ' service ' ': Name or service not known
感谢朋友支持本博客,欢迎共同探讨交流,因为能力和时间有限,错误之处在所难免.欢迎指正. 假设转载,请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...
- 【SQLServer2008】之Win10 安装 SQL Server 2008
查看安装步骤链接: http://jingyan.baidu.com/article/1709ad8092be974634c4f0e7.html
- VMWare Workstation和VMWare vSphere(转)
VMware workstation一定是安装在window操作系统上的. VMware vSphere可以直接安装在x86机器上,使这台机器完全虚拟化. VMware vSphere主要是企业级用户 ...
- InitialContext和lookup
http://wxg6203.iteye.com/blog/680830 最近因为工作需要开始学习Ejb3,遇到了一个让我很郁闷的事情,做一下小小的总结——小心new InitialContext() ...
- 如何通过git客户端上传项目到github上
参考地址: 1.http://1ke.co/course/194 2.https://github.com/wohugb/git-reference/blob/master/Git-on-the-Se ...
- PHPUnit_Framework_Assert单元测试
先发下简书的干货: 教你一步一步写一个phpunit testcase:https://www.jianshu.com/p/ba6829a6f3ec 程序地址 https://github.com/y ...