银行家算法程序c语言,银行家算法代码c语言编写.doc

银行家算法程序c语言,银行家算法代码c语言编写.doc#defineM100#includeintmax[M][M],allocation[M][M],need[M][M],available[M];inti,j,n,m,r;voidtestout()//算法安全性的检测{intk,flag,v=0;intwork[M],a[M];charfinish[M];r=1;for(i…

大家好,又见面了,我是你们的朋友全栈君。

#define M 100

#include

int max[M][M],allocation[M][M],need[M][M],available[M];

int i,j,n,m,r;

void testout() //算法安全性的检测

{ int k,flag,v=0;

int work[M],a[M];

char finish[M];

r=1;

for(i=0;i

finish[i]=’F’; //初始化各进程均没得到足够资源

for(j=0;j

work[j]=available[j]; //用work[j]表示可提供进程继续运行的各类资源数

k=n;

while(k>0)

{

for (i=0;i

{if (finish[i]==’F’)

{ flag=1;

for (j=0;j

if (need[i][j]>work[j])

flag=0;

if (flag==1) //找到还没完成的且需求数小于可提供进程继续运行的

{ finish[i]=’T’; //资源数的进程

a[v++]=i; //记录安全序列

for (j=0;j

work[j]=work[j]+allocation[i][j]; //释放该进程已分配的资源

}

}

}

k–;

}

flag=1;

for (i=0;i

if (finish[i]==’F’)

flag=0;

if (flag==0) //若有进程没完成,则为不安全状态

{

printf(“系统不安全 . \n”);

r=0;

}

else //否则为安全状态

{

printf(“系统是安全的 .\n”);

printf(” 输出安全序列:\n”);

for (i=0;i

printf (“%d “,a[i]); //输出安全序列

printf(“\n”);

for (i=0;i

{

printf(“%2d”,i);

printf(” “);

for(j=0;j

printf(“%2d”,allocation[i][j]);

printf(” “);

for(j=0;j

printf(“%2d”,need[i][j]);

printf(“\n”);

}

}

}

void print() //输出可用资源数目

{

printf(“可用资源是: \n”);

for(j=0;j

printf(“%2d “,available[j]);

printf(“\n”);

}

void main()

{

int

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/140837.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • rc522 nfc_基于单片机的门禁系统

    rc522 nfc_基于单片机的门禁系统文章目录1.前言(包括一些个人理解)1.前言(包括一些个人理解)(2021/11/1编辑)在项目需要做一个NFC门禁功能的时候,突然发现有个RC522丢在我的桌面,甚至不知道它上面的引脚什么意思(还不会SPI通讯),搜索关键词“RC522”去看博客搜索资料,发现了很多都在说扇区,块,S50(M1)卡,然后就给代码,一开始我还以为S50是内嵌在这个模块里面的一个存储器,然后越看越怪,后面去淘宝搜索S50,才发现S50其实是我们的门禁卡,RC522是用来感应和判断的。…

    2022年9月16日
    4
  • Oracle列转行函数 Listagg() 语法详解及应用实例「建议收藏」

    Oracle列转行函数 Listagg() 语法详解及应用实例「建议收藏」工作中用到一段比较复杂的SQL查询脚本,使用了listagg()函数实现了具有多个值的字段的填充(即,列表聚合,listaggregation(我猜的))。说简单点,listagg()函数可以实现多列记录聚合为一条记录,从而实现数据的压缩、致密化(datadensification)。以下内容转载自http://dacoolbaby.iteye.com/blog/1698957,SQL脚本做了…

    2025年8月29日
    7
  • Windows程序设计——窗口键盘消息滚动事件[通俗易懂]

    Windows程序设计——窗口键盘消息滚动事件[通俗易懂]设置头文件#include <Windows.h>#include “systems.h”以下是头文件内容#pragma once#include <Windows.h>#define NUMLINES ((int)(sizeof sysmetrics/sizeof sysmetrics[0]))struct { int Index; char sz…

    2022年8月18日
    9
  • G6流程图绘制

    G6流程图绘制为了能在线编辑流程 支持流程节点编辑等功能 支持人员等选择功能 支持流程图数据保存 利用阿里 G6 进行设计开发 整体效果图如下 支持放大缩小 节点移动 添加节点及边等 同时支持节点及边删除操作 流程图数据保存等工作 支持节点编辑 包括人员选择 图形选择 宽高编辑 背景色 边框色等信息编辑 支持边的编辑 边描述等 各种交互功能就不赘述了 页面代码如下 DOCTYPE YPE html head head html

    2025年7月25日
    2
  • JavaWeb项目(登录注册页面)全过程详细总结

    JavaWeb项目(登录注册页面)全过程详细总结JavaWeb项目(登录注册页面)全过程总结文章目录JavaWeb项目(登录注册页面)全过程总结一、环境准备与开发工具二、创建JavaWeb项目2.1新建DynamicWebProject项目2.2创建前端页面2.2.1登录页面1.login.jsp2.login.js3.time.js4.focus.js+animate.js2.2.2注册页面(register.jsp)2.2.3修改密码的页面(change_pwd.jsp)2.2.4登录成功的页面(success.jsp

    2022年7月18日
    26
  • FastAI 课程学习笔记 lesson 1:宠物图片分类

    FastAI 课程学习笔记 lesson 1:宠物图片分类文章目录代码解析神奇的”%”导入fastAI库下载解压数据集untar_data获取帮助文档help()???doc设置路径get_image_filesImageDataBunchfrom_name_regrep命令检验正则表达式pythonre检验正则表达式代码解析神奇的”%”%reload_extautoreload%autoreload2%matplotlibinli…

    2025年10月6日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号