- 11
- 0
- 约6.2千字
- 约 10页
- 2018-01-02 发布于河南
- 举报
最佳适应算法_最坏适应算法2
最佳适应算法_最坏适应算法2
#includestdio.h
#includestdlib.h
#includeiostream.h
#define Free 0 //空闲状态
#define Busy 1 //已用状态
#define OK 1 //完成
#define ERROR 0 //出错
#define MAX_length 100 //最大内存空间为100M
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 Best_fit(int); //最佳适应算法
Status Worst_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请输入需要分配的主存大小(单位:M):;
cinrequest;
if(request0 ||request==0)
{
cout分配大小不合适,请重试!endl;
return ERROR;
}
if(ch==1) //选择最佳适应算法
{
if(Best_fit(request)==OK) cout分配成功!endl;
else cout内存不足,分配失败!endl;
return OK;
}
if(ch==2) //选择最差适应算法
{
if(Worst_fit(request)==OK) cout分配成功!endl;
else cout内存不足,分配失败!endl;
return OK;
}
}
//最佳适应算法
Status Best_fit(int request)
{
int ch; //记录最小剩余空间
DuLinkList temp=(DuLinkList)malloc(sizeof(DuLNode));//申请内存空间
temp-data.size=request;
temp-data.state=Busy;
DuLNode *p=block_first-next;
DuLNode *q=NULL; //记录最佳插入位置
while(p) //初始化最小空间和最佳位置
{
if(p-data.state==Free (p-data.size=request) )
{
if(q==NULL)
您可能关注的文档
最近下载
- 附件: 黑龙江省年“村村大学生计划(培养)” 招 生 简 章 “村村 .doc VIP
- 往年江苏省教师招聘考试教育学心理学真题及答案.docx VIP
- 国资集团考试试题及答案.docx VIP
- 部编版语文一年级下册阅读11《浪花》课件PPT.pptx VIP
- 2018海湾GST-QKP04、GST-QKP04 2气体灭火控制器说明书.docx
- 浙江省杭州市西湖区之江中学2024-2025学年高二上学期期末数学试题(解析版).docx VIP
- 人教版五年级上册数学期末测试卷及参考答案ab卷.docx VIP
- [中央]2025年中国建设银行建信养老金管理有限责任公司校园招聘20人笔试历年参考题库频考点试题附带答案详解.docx
- 海南省公务员考试模拟试题库《行测》部分及参考答案.docx VIP
- BS EN 14540-2014 国外国际规范.pdf VIP
原创力文档

文档评论(0)