- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
作业管理-最短作业优先算法2
计算机信息工程学院学生实验报告
专业:网络工程 姓名: 杨俊光 学号: 0808060198 日期: 2010.3.26
课程名称 数据结构 实验室名称 X4313 实验名称 作业管理之最短作业优先算法 指导教师 朱明华 成绩 实验目的:熟悉操作系统作业管理步骤,用C语言编程模拟实现最短作业优先算法。 实验步骤:
分析问题,提出解决问题的算法
编制程序
程序调试
记录实验结果,以及思考是否能够改善算法
程序及运行结果(或实验数据记录及分析):
#include stdio.h
#include string.h
typedef struct node{
char c;//作业名
int flag;//表示执行的次序,1表示最先执行
int intInputTime;//进入时间
int intRunTime;//运行时间
int intStartTime;//开始时间
int intFinishTime;//完成时间
char charInputTime[6];//进入时间(时分制)
int intHourStartTime;//开始时间(小时部分)
int intMinutesStartTime;//开始时间(分钟部分)
int intHourFinishTime;//完成时间(小时部分)
int intMinutesFinishTime;//完成时间(分钟部分)
int turnaroundTime;//周转时间
float weightedTurnaroundTime;//加权周转时间
}shortest_job_first;
int hourToMinutes(char s[])//把时分制转换为分钟
{
int sum;
if(s[1]==:)
sum=60*((int)s[0]-48)+10*((int)s[2]-48)+((int)s[3]-48);
if(s[2]==:)
sum=600*((int)s[0]-48)+60*((int)s[1]-48)+10*((int)s[3]-48)+(s[4]-48);
//printf($%c %c %c %c$\n,s[0],s[1],s[2],s[3]);
return sum;
}
int minutesToHour(int t)//提取分钟中的小时
{
int k;
k=t/60+48;
return k;
}
int minutesToMinutes(int t)//提取分钟中的分钟
{
int k;
k=t%60+48;
return k;
}
main()
{
//本程序所测试的数据必须是:第一个作业时最先进入的,而且最先进来的作业执行完之后其余作业都已经进入等待队列
shortest_job_first num[20];
int i,j,k,n,temp=1440,t1,t2=1,lastFinishTime;//t1用于排序时记录下标,t2用于记录排序后序号
int sumTurnaroundTime=0;//总的周转时间
float averageTurnaroundTime,sumWeightedTurnaroundTime=0.0,averageWeightedTurnaroundTime;
printf(请输入总的作业数:);//lastFinishTime表示上一个作业的完成时间
scanf(%d,n);
printf(请依次输入作业名(一个字符)进入时间和运行时间:\n);
for(i=1;i=n;i++)
{
getchar();
scanf(%c %s %d,num[i].c,num[i].charInputTime,num[i].intRunTime);
num[i].intInputTime=hourToMinutes(num[i].charInputTime);
num[i].flag=0;//表示未排序
}
num[1].flag=1;
for(i=2;i=n;i++)
{
temp=1440;
for(j=2;j=n;j++)
{
if((!num[j].flag)num[j].intRunTimetemp)
{
temp=num[j].intRunTime;
t1=j;
}
}
t2++;
num[t1].flag=t2;
}
num[1].intStartTime=num[1].intInputTime;
num[1].intFinishTi
您可能关注的文档
最近下载
- 2003年房地产估师考试《房地产开发经营与管理》真题及答案-中大网校.doc VIP
- 职业生涯报告六篇.pdf VIP
- 弧度制、扇形的弧长与面积.PDF VIP
- 2024-2030年中国纺织行业十四五发展分析及投资前景与战略规划研究报告.docx VIP
- 2025云南省交通投资建设集团有限公司下属云南省交通科学研究院有限公司管理人员招聘16人笔试参考题库附答案解析.docx VIP
- 《电子商务安全技术》考试复习题库(含答案).docx VIP
- 人工智能数学基础-全套PPT课件.pptx
- 山东名校2025届高三12月校际联合检测 生物试卷(含答案解析).docx
- 职业计划生涯范文5篇.docx VIP
- 成功必备的八大心态.ppt VIP
原创力文档


文档评论(0)