动态分区分配算法代码c语言,并写出注释

时间: 2024-03-13 12:38:34 浏览: 31
```c #include <stdio.h> #include <stdlib.h> #define MAX 100 //最大分区数 struct node{ //定义分区结构体 int id; //分区编号 int sp; //分区起始地址 int ep; //分区结束地址 int longsize; //分区长度 }a[MAX],b[MAX]; //a为作业分区,b为空闲分区 void Init(int anum,int bnum,int size){ //初始化分区 a[0].id = 1; a[0].sp = 0; a[0].ep = size-1; a[0].longsize = size; for(int i=1;i<anum;i++){ a[i].id = i+1; a[i].sp = -1; a[i].ep = -1; a[i].longsize = -1; } for(int i=0;i<bnum;i++){ b[i].id = i+1; b[i].sp = -1; b[i].ep = -1; b[i].longsize = -1; } } void FirstFit(int anum,int bnum,int size,int jobsize){ //首次适应算法 int flag = 0; //标记是否分配成功 for(int i=0;i<bnum;i++){ if(b[i].longsize >= jobsize){ //找到第一个满足要求的空闲分区 flag = 1; a[anum].id = anum+1; a[anum].sp = b[i].sp; a[anum].ep = b[i].sp+jobsize-1; a[anum].longsize = jobsize; b[i].sp += jobsize; b[i].longsize -= jobsize; if(b[i].longsize == 0){ //如果空闲分区被用完,删除该分区 for(int j=i;j<bnum-1;j++){ b[j] = b[j+1]; } b[bnum-1].id = -1; b[bnum-1].sp = -1; b[bnum-1].ep = -1; b[bnum-1].longsize = -1; bnum--; } anum++; break; } } if(flag == 0){ //分配失败 printf("分配失败!\n"); } else{ //分配成功 printf("分配成功!\n"); printf("分配后的作业分区表:\n"); printf("作业分区 起始地址 结束地址 长度\n"); for(int i=0;i<anum;i++){ printf(" %d %d %d %d\n",a[i].id,a[i].sp,a[i].ep,a[i].longsize); } printf("分配后的空闲分区表:\n"); printf("空闲分区 起始地址 结束地址 长度\n"); for(int i=0;i<bnum;i++){ printf(" %d %d %d %d\n",b[i].id,b[i].sp,b[i].ep,b[i].longsize); } } } void BestFit(int anum,int bnum,int size,int jobsize){ //最佳适应算法 int flag = 0; //标记是否分配成功 int min = size+1; //记录最小的空闲分区长度 int index = -1; //记录最小的空闲分区下标 for(int i=0;i<bnum;i++){ if(b[i].longsize >= jobsize && b[i].longsize < min){ //找到满足要求的最小空闲分区 flag = 1; min = b[i].longsize; index = i; } } if(flag == 1){ //分配成功 a[anum].id = anum+1; a[anum].sp = b[index].sp; a[anum].ep = b[index].sp+jobsize-1; a[anum].longsize = jobsize; b[index].sp += jobsize; b[index].longsize -= jobsize; if(b[index].longsize == 0){ //如果空闲分区被用完,删除该分区 for(int j=index;j<bnum-1;j++){ b[j] = b[j+1]; } b[bnum-1].id = -1; b[bnum-1].sp = -1; b[bnum-1].ep = -1; b[bnum-1].longsize = -1; bnum--; } anum++; printf("分配成功!\n"); printf("分配后的作业分区表:\n"); printf("作业分区 起始地址 结束地址 长度\n"); for(int i=0;i<anum;i++){ printf(" %d %d %d %d\n",a[i].id,a[i].sp,a[i].ep,a[i].longsize); } printf("分配后的空闲分区表:\n"); printf("空闲分区 起始地址 结束地址 长度\n"); for(int i=0;i<bnum;i++){ printf(" %d %d %d %d\n",b[i].id,b[i].sp,b[i].ep,b[i].longsize); } } else{ //分配失败 printf("分配失败!\n"); } } void Release(int anum,int bnum){ //回收分区 int id; printf("请输入要回收的分区编号:"); scanf("%d",&id); int flag = 0; //标记是否找到要回收的分区 for(int i=0;i<anum;i++){ if(a[i].id == id){ //找到要回收的分区 flag = 1; for(int j=0;j<bnum;j++){ if(b[j].sp > a[i].ep){ //找到要回收的分区后面的空闲分区 for(int k=bnum;k>j;k--){ //将空闲分区后移 b[k] = b[k-1]; } b[j].id = bnum+1; b[j].sp = a[i].sp; b[j].ep = a[i].ep; b[j].longsize = a[i].longsize; bnum++; break; } } for(int j=i;j<anum-1;j++){ //将作业分区后移 a[j] = a[j+1]; } a[anum-1].id = -1; a[anum-1].sp = -1; a[anum-1].ep = -1; a[anum-1].longsize = -1; anum--; printf("回收成功!\n"); printf("回收后的作业分区表:\n"); printf("作业分区 起始地址 结束地址 长度\n"); for(int i=0;i<anum;i++){ printf(" %d %d %d %d\n",a[i].id,a[i].sp,a[i].ep,a[i].longsize); } printf("回收后的空闲分区表:\n"); printf("空闲分区 起始地址 结束地址 长度\n"); for(int i=0;i<bnum;i++){ printf(" %d %d %d %d\n",b[i].id,b[i].sp,b[i].ep,b[i].longsize); } break; } } if(flag == 0){ //未找到要回收的分区 printf("未找到要回收的分区!\n"); } } int main(){ int anum = 1; //作业分区数 int bnum = 1; //空闲分区数 int size; //主存大小 int jobsize; //作业大小 int choice; //用户选择的操作 printf("请输入主存大小:"); scanf("%d",&size); printf("请输入作业大小:"); scanf("%d",&jobsize); Init(anum,bnum,size); //初始化分区 while(1){ printf("请选择要进行的操作:\n"); printf("1.首次适应算法\n"); printf("2.最佳适应算法\n"); printf("3.回收分区\n"); printf("4.退出程序\n"); printf("请输入操作编号:"); scanf("%d",&choice); switch(choice){ case 1: FirstFit(anum,bnum,size,jobsize); //首次适应算法 break; case 2: BestFit(anum,bnum,size,jobsize); //最佳适应算法 break; case 3: Release(anum,bnum); //回收分区 break; case 4: exit(0); //退出程序 default: printf("输入错误,请重新输入!\n"); break; } } return 0; } ``` 注释: 1.定义分区结构体,包括分区编号、起始地址、结束地址和长度。 2.初始化分区,将第一个作业分区设置为整个主存,其余作业分区和空闲分区设置为-1。 3.首次适应算法,遍历空闲分区表,找到第一个满足要求的空闲分区,将其分配给作业分区,更新作业分区表和空闲分区表。 4.最佳适应算法,遍历空闲分区表,找到满足要求的最小空闲分区,将其分配给作业分区,更新作业分区表和空闲分区表。 5.回收分区,输入要回收的分区编号,找到要回收的作业分区,将其释放并合并相邻的空闲分区,更新作业分区表和空闲分区表。 6.主函数,初始化分区,循环执行用户选择的操作,包括首次适应算法、最佳适应算法、回收分区和退出程序。

相关推荐

最新推荐

recommend-type

动态分区分配方式模拟(c语言)

用C 语言实现对采用首次适应算法和最佳适应算法的动态分区分配过程ALLOC()和回收过程FREE(),其中空闲分区由空闲分区链来管理,进行分配时,系统优先使用空闲区底端空间。
recommend-type

C语言字符串快速压缩算法代码

主要介绍了C语言字符串快速压缩算法代码,将字符串中连续出席的重复字母进行压缩,其主要的压缩字段的格式为”字符重复的次数+字符”。有需要的小伙伴参考下吧。
recommend-type

c语言文件操作常用函数及读写文件代码举列

文章主要例举一个c语言文件操作常用函数及读写文件的代码,感性趣的朋友可以看看。
recommend-type

C语言矩阵连乘 (动态规划)详解

主要介绍了C语言矩阵连乘 (动态规划)详解的相关资料,需要的朋友可以参考下
recommend-type

C语言找出数组中的特定元素的算法解析

主要介绍了C语言中找出数组中特定元素的算法解析,包括找出数组中两个只出现一次的数字的方法,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。