ImageVerifierCode 换一换
格式:DOC , 页数:18 ,大小:14.02KB ,
资源ID:2583453      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-2583453.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(电梯优先调度算法.doc)为本站会员(weiwoduzun)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

电梯优先调度算法.doc

1、电梯优先调度算法电梯调度算法(ms InterView) 移臂调度算法包括以下四种:1) 先来先服务算法:根据访问者提出访问请求的先后次序来决定执行次序。2) 最短寻找时间优先调度算法:从等待的访问者中挑选寻找时间最短的那个请求执行,而不管访问者的先后次序。3) 电梯调度扫描算法:从移动臂当前位置沿移动方向选择最近的那个柱面的访问者来执行,若该方向上无请求访问时,就改变移动方向再选择。4) 单向扫描调度算法:从 0 柱面开始往里单向扫描,扫到哪个执行哪个。*/ / t1.cpp : 定义控制台应用程序的入口点。 / #include stdafx.h #includemath.h #inclu

2、destdlib.h #includestring.h struct Head int nPosition; bool bVisited; ; void Visit(struct Head *pHead) printf(visite cy:%dn,pHead-nPosition); pHead-bVisited=true; int ReadInputKeyboard(struct Head *pHead,int *pCurrentPosition,int nMaxNumber) int i; printf(please input Current position:); scanf(%d,pC

3、urrentPosition); printf(please input will visit position:); for(i=0;inMaxNumber;i+) scanf(%d,pHeadi.nPosition); pHeadi.bVisited=false; if(pHeadi.nPosition0) break; return i; int ReadInputFile(struct Head *pHead,int *pCurrentPosition,int nMaxNumber) int i; char szFileName256,*q,*p,szTemp20; printf(pl

4、ease input filename:); scanf(%s,szFileName); FILE *pFile=fopen(szFileName,r); if(pFile=NULL) printf(open file %s error,szFileName); return -1; for(i=0;!feof(pFile) inMaxNumber;) p=szFileName; fgets(p,256,pFile); while(q=strchr(p,) memset(szTemp,0,sizeof(szTemp)*sizeof(char); strncpy(szTemp,p,q-p); p

5、=q+1; if(i=0) *pCurrentPosition=atoi(szTemp); else pHeadi-1.nPosition=atoi(szTemp); pHeadi-1.bVisited=false; i+; memset(szTemp,0,sizeof(szTemp)*sizeof(char); pHeadi-1.nPosition=atoi(p); pHeadi-1.bVisited=false; /i+; fclose(pFile); return i; int FifoVisit(int nCurrentPosition,struct Head *pHead,int n

6、Number) /先来先服务 int nHaveVisited=0; int nMoveDistance=0; int i; while(nHaveVisitednNumber) for(i=0;inNumber;i+) if(pHeadi.bVisited) continue; Visit(pHeadi); nHaveVisited+; nMoveDistance+=abs(nCurrentPosition-pHeadi.nPosition); nCurrentPosition=pHeadi.nPosition; printf(the sum of move distance:%dn,nMo

7、veDistance); return nMoveDistance; int SsfoVisit(int nCurrentPosition,struct Head *pHead,int nNumber) / 最短寻找时间优先 int nHaveVisited=0; int nMoveDistance=0; int nMinDistance=0; int nMinIndex=0; int i; while(nHaveVisitednNumber) nMinDistance=0xffff; nMinIndex=0; /找最小值 for(i=0;inNumber;i+) if(pHeadi.bVis

8、ited) continue; if(nMinDistanceabs(pHeadi.nPosition-nCurrentPosition) nMinDistance=abs(pHeadi.nPosition-nCurrentPosition); nMinIndex=i; /访问 Visit(pHeadnMinIndex); nHaveVisited+; nMoveDistance+=nMinDistance; nCurrentPosition=pHeadnMinIndex.nPosition; printf(the sum of move distance:%dn,nMoveDistance)

9、; return nMoveDistance; int DtVisit(int nCurrentPosition,bool bOut,struct Head *pHead,int nNumber) /电梯调度算法 int nHaveVisited=0; int nMoveDistance=0; int nMinDistance=0; int nMinIndex=0; int i; while(nHaveVisitednNumber) nMinDistance=0xffff; nMinIndex=0; /找最小值 for(i=0;inNumber;i+) if(pHeadi.bVisited)

10、continue; if(bOutpHeadi.nPositionnCurrentPosition|!bOutpHeadi.nPositionnCurrentPosition) if(nMinDistanceabs(pHeadi.nPosition-nCurrentPosition) nMinDistance=abs(pHeadi.nPosition-nCurrentPosition); nMinIndex=i; if(nMinDistance=0xffff) bOut=!bOut; continue; /访问 Visit(pHeadnMinIndex); nHaveVisited+; nMo

11、veDistance+=nMinDistance; nCurrentPosition=pHeadnMinIndex.nPosition; printf(the sum of move distance:%dn,nMoveDistance); return nMoveDistance; int DxVisit(int nCurrentPosition,struct Head *pHead,int nNumber) /单向调度算法 int nHaveVisited=0; int nMoveDistance=0; int nMinDistance=0; int nMinIndex=0; int i;

12、 while(nHaveVisitednNumber) nMinDistance=0xffff; nMinIndex=0; /找最小值 for(i=0;inNumber;i+) if(pHeadi.bVisited) continue; if(pHeadi.nPositionnCurrentPosition ) if(nMinDistanceabs(pHeadi.nPosition-nCurrentPosition) nMinDistance=abs(pHeadi.nPosition-nCurrentPosition); nMinIndex=i; if(nMinDistance=0xffff)

13、 nMoveDistance+=199-nCurrentPosition; nCurrentPosition=0; continue; /访问 Visit(pHeadnMinIndex); nHaveVisited+; nMoveDistance+=nMinDistance; nCurrentPosition=pHeadnMinIndex.nPosition; printf(the sum of move distance:%dn,nMoveDistance); return nMoveDistance; int main(int argc, char* argv) /p114 struct

14、Head mylist20;/=98,false,183,false,37,false,122,false,14,false,124,false,65,false,67,false; /int nCurrentPosition=53; /int nRealNumber=8; int nCurrentPosition=0; int nRealNumber=ReadInputFile(mylist,nCurrentPosition,20); / FifoVisit(nCurrentPosition,mylist,nRealNumber); / SsfoVisit(nCurrentPosition,mylist,nRealNumber); /DtVisit(nCurrentPosition,false,mylist,nRealNumber); DxVisit(nCurrentPosition,mylist,nRealNumber); return 0;

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报