#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h> // bool 类型 int N = 0; // 进程数目
int M = 0; // 资源数目
int* Available; // 可利用资源向量 M
int** Max; // 最大需求矩阵 M * N
int** Allocation; // 分配矩阵 M * N
int** Need; // 需求矩阵 M * N // 初始化数据结构
void init(); // 销毁数据结构
void destory(); // 安全性检查算法
void security_checks(); int main(int argc, char const *argv[]) {
init();
security_checks();
destory();
return 0;
} /**
* 初始化数据结构
*/
void init() {
printf("依次输入进程数目和资源类型数目:");
scanf("%d%d", &N, &M); // 分配内存
Available = malloc(sizeof(int*) * N);
Max = malloc(sizeof(int*) * N);
Allocation = malloc(sizeof(int*) * N);
Need = malloc(sizeof(int*) * N);
for (int i = 0; i < N; i++) {
Max[i] = malloc(sizeof(int) * M);
Allocation[i] = malloc(sizeof(int) * M);
Need[i] = malloc(sizeof(int) * M);
} // 赋值
for (int i = 0; i < M; i++) {
printf("输入资源类型%d的数目:", i);
scanf("%d", &(Available[i]));
} for (int i = 0; i < N; i++) {
for (int j = 0; j < M; j++) {
printf("依次输入进程%d对资源类型%d的最大需求及已获得的数量:", i, j);
scanf("%d%d", &(Max[i][j]), &(Allocation[i][j]));
Available[j] -= Allocation[i][j];
Need[i][j] = Max[i][j] - Allocation[i][j];
}
}
} /**
* 销毁数据结构
*/
void destory() {
free(Available);
for (int i = 0; i < N; i++) {
free(Max[i]);
free(Need[i]);
free(Allocation[i]);
}
} /**
* 安全性检查算法
*/
void security_checks() {
int Work[M];
bool Finish[N];
for (int i = 0; i < N; i++) {
Finish[i] = false;
}
for (int i = 0; i < M; i++) {
Work[i] = Available[i];
} int finish_count = 0; // 结束任务的进程数目
char security_seq[N][5]; // 安全序列
while (true) {
bool had_allocated = false; // 判断本轮是否分配
for (int i = 0; i < N; i++) {
if (Finish[i] == false) { // 找一个没有结束的进程
bool all_valid = true;
for (int j = 0; j < M; j++) { // 如果对所有资源的Need[i][j]都小于Work[j],则分配
if (Need[i][j] > Work[j]) { // 但凡有一个不满足,则不分配
all_valid = false;
break;
}
}
if (all_valid == true) { // 分配并回收资源
for (int j = 0; j < M; j++) {
Work[j] += Allocation[i][j];
}
Finish[i] = true;
had_allocated = true;
sprintf(security_seq[finish_count++], "P%d\0", i);
}
}
}
if (finish_count == N) { // 结束,安全
puts("系统处于安全状态");
printf("进程安全序列为:");
for (int i = 0; i < N; i++) { // 输出安全序列
printf("[%s]", security_seq[i]);
if (i != N - 1) printf(" => ");
else puts("");
}
return ;
} else if (had_allocated == false) { // 结束,不安全
puts("系统处于不安全状态");
return ;
}
}
}

  

C语言实现银行家算法的更多相关文章

  1. 【操作系统】银行家算法实现(C语言)

    [操作系统]银行家算法实现(C语言) 注意:本人编码水平很菜.算是自己的一个总结.可能会有我还没有发现的bug.如果有人发现后可以指出,不胜感激. 1.银行家算法: 我们可以把操作系统看作是银行家,操 ...

  2. C语言实现 操作系统 银行家算法

    /**************************************************** 银行家算法 算法思想: 1. 在多个进程中,挑选资源需求最小的进程Pmin. 可能存在多类资 ...

  3. C# Math.Round()的银行家算法

    可能很多人都跟我一样,都只知道Math.Round()是C#中用来做四舍五入,保留指定小数位的 但实际上它并不是真正的四舍五入,而是银行家算法的四舍六入五取偶 事实上这也是IEEE的规范,因此所有符合 ...

  4. c/c++多线程模拟系统资源分配(并通过银行家算法避免死锁产生)

    银行家算法数据结构 (1)可利用资源向量Available 是个含有m个元素的数组,其中的每一个元素代表一类可利用的资源数目.如果Available[j]=K,则表示系统中现有Rj类资源K个. (2) ...

  5. Round() 四舍五入 js银行家算法(转)

    首先问一下round(0.825,2) 返回的结果,大家猜一猜, 首先SQL server 返回的是 0.83 js的返回结果 是0.83,code 如下: var b = 0.825;        ...

  6. 10个经典的C语言面试基础算法及代码

    10个经典的C语言面试基础算法及代码作者:码农网 – 小峰 原文地址:http://www.codeceo.com/article/10-c-interview-algorithm.html 算法是一 ...

  7. 数据结构C语言版 弗洛伊德算法实现

    /* 数据结构C语言版 弗洛伊德算法  P191 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h>#include <limits.h> # ...

  8. 银行家算法java实现

    关于银行家算法的理论知识,课本或者百度上有好多资料,我就不再多说了,这里把我最近写的银行家算法的实现带码贴出来. 由于这是我们的一个实验,对系统资源数和进程数都指定了,所以这里也将其指定了,其中系统资 ...

  9. 操作系统,银行家算法模拟实现(Windows 环境 C++)

    计算机操作系统课设需要,写了两个下午的银行家算法(陷在bug里出不来耽误了很多时间),参考计算机操作系统(汤子瀛) 实现过程中不涉及难度较大的算法,仅根据银行家算法的思想和步骤进行实现.以下为详细步骤 ...

随机推荐

  1. 1087 有多少不同的值 (20 分)C语言

    当自然数 n 依次取 1.2.3.--.N 时,算式 ⌊n/2⌋+⌊n/3⌋+⌊n/5⌋ 有多少个不同的值?(注:⌊x⌋ 为取整函数,表示不超过 x 的最大自然数,即 x 的整数部分.) 输入格式: ...

  2. 看完这篇HTTP,跟面试官扯皮就没问题了

    我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟.醍醐灌顶的感觉. 最初在有 ...

  3. 前端页面表格排序 jQuery Table 基础

    通常来说, 排序的方式有两种, 一种是我们在查询的时候就排好序,然后将数据渲染到前台页面上, 但是这样做有个弊端,就是在争对做好了缓存处理的系统, 在查询相同数据的时候进行排序,可能不能成功, 因为进 ...

  4. 我怎么感觉 ConcurrentDictionary<,> 不是线程安全的喃?

    直接上代码 class Program { static readonly ConcurrentDictionary<string, Person> Dic = new Concurren ...

  5. 【原创】Dubbo 2.7.5在线程模型上的优化

    这是why技术的第30篇原创文章 这可能是全网第一篇解析Dubbo 2.7.5里程碑版本中的改进点之一:客户端线程模型优化的文章. 先劝退:文本共计8190字,54张图.阅读之前需要对Dubbo相关知 ...

  6. MOS 常用链接地址

    主页面类  Exadata主页面 Exadata Database Machine and Exadata Storage Server Supported Versions (Doc ID 8888 ...

  7. 所有锁的unlock要放到try{}finally{}里,不然发生异常返回就丢了unlock了

    所有锁的unlock要放到try{}finally{}里,不然发生异常返回就丢了unlock了

  8. excel中为什么不显示单引号

    解决:打两个就可以了!因为:一个单引号表示该单元格为文本属性.

  9. ancconda创建爬虫项目

    # 安装 conda env list conda create -n <envname> conda activate <envname> conda install scr ...

  10. elasticjob学习一:simplejob初识和springboot整合

    Elastic-Job是一个分布式调度解决方案,由两个相互独立的子项目Elastic-Job-Lite和Elastic-Job-Cloud组成. Elastic-Job-Lite定位为轻量级无中心化解 ...