- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
首次适应算法和最佳适应算法-C语言版
#includeiostream
#includestdlib.h
using namespace std;
#define Free 0 //空闲状态
#define Busy 1 //已用状态
#define OK 1 //完成
#define ERROR 0 //出错
#define MAX_length 512 //最大内存空间为512KB
typedef int Status;
int flag;
typedef struct freearea//定义一个空闲区说明表结构
{
long size; //分区大小
long address; //分区地址
int state; //状态
}ElemType;
// 线性表的双向链表存储结构
typedef struct DuLNode
{
ElemType data;
struct DuLNode *prior; //前趋指针
struct DuLNode *next; //后继指针
}
DuLNode,*DuLinkList;
DuLinkList block_first; //头结点
DuLinkList block_last; //尾结点
Status alloc(int);//内存分配
Status free(int); //内存回收
Status First_fit(int);//首次适应算法
Status Best_fit(int); //最佳适应算法
void show();//查看分配
Status Initblock();//开创空间表
Status Initblock()//开创带头结点的内存空间链表
{
block_first=(DuLinkList)malloc(sizeof(DuLNode));
block_last=(DuLinkList)malloc(sizeof(DuLNode));
block_first-prior=NULL;
block_first-next=block_last;
block_last-prior=block_first;
block_last-next=NULL;
block_last-data.address=0;
block_last-data.size=MAX_length;
block_last-data.state=Free;
return OK;
}
//分配主存
Status alloc(int ch)
{
int request = 0;
cout请输入需要分配的主存大小(单位:KB):;
cinrequest;
if(request0 ||request==0)
{
cout分配大小不合适,请重试!endl;
return ERROR;
}
if(ch==2) //选择最佳适应算法
{
if(Best_fit(request)==OK) cout分配成功!endl;
else cout内存不足,分配失败!endl;
return OK;
}
else //默认首次适应算法
{
if(First_fit(request)==OK) cout分配成功!endl;
else cout内存不足,分配失败!endl;
return OK;
}
}
//首次适应算法
Status First_fit(int request)
{
//为申请作业开辟新空间且初始化
DuLinkList temp=(DuLinkList)malloc(sizeof(DuLNode));
temp-data.size=request;
temp-data.state=Busy;
DuLNode *p=block_first-next;
while(p)
{
if(p-data.state==Free p-data.size==request)
{//有大小恰好合适的空闲块
p-data.state=Busy;
return OK;
break;
}
if(p-data.state==Free p-data.sizerequest)
{//有空闲块能满足需求且
您可能关注的文档
- 2017年-中国特色社会主义理论体系概论形成性考核册选择题.doc
- 2017年-初中毕业学业考试中考仿真-语文A.docx
- 2017年-大-毛概课后题答案及-往年重点题.docx
- 2017年-成都市中考英语真题(含答案).docx
- 2017年-最新电大-计算机应用基础WIN7形成性考核册答案.docx
- 2017年-欧洲车身会议(Euro-Car-Body)总结.pdf
- 2017年0-6岁儿童健康管理项目试题.doc
- 2017年-高三地理(地图和地球运动)9月阶段测试题.doc
- 2017年04月自学考试00262《法律文书写作》题目及答案.doc
- 2017年1-6单元八校联考化学试卷及答题卡.docx
- 林德115系列叉车维修手册 英文.pdf
- 林德E16C-03, E16P-03, E20P-03叉车维修手册 英文.pdf
- 林德H50T叉车维修手册 英文.pdf
- 6.1.2 化学反应与电能 课件高一下学期化学人教版(2019) 必修第二册.pptx
- 零碳项目初步设计(模板).docx
- 金融从业者必懂的宏观经济指标实战指南:2025年投资策略与市场分析.docx
- 第二章 第二节 氯及其化合物-第1课时 氯气的性质课件高一上学期化学人教版(2019)必修第一册.pptx
- 产品经理完全指南:Axure原型设计从入门到实战全解.docx
- 6.1.2 影响化学反应速率的因素 课件高一下学期化学苏教版(2020)必修第二册.pptx
- 零碳项目融资方案(模板).docx
文档评论(0)