银行家算法程序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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • CEGUI 动画

    CEGUI 动画最新的版本支持动画,使用Animation类.项目中使用的是7.1的版本,不支持动画,leader说不使用最新版本的CEGUI库,就使用7.1,无奈,自己写一个动画类吧.CEGUI中播放动画是将一个动画的每帧连续不断的画到屏幕上,就形成了动画.就像小时候在书的边页上面画的小人,每一页都画一个小人,每个小人的动作都有点不同,这样快速翻书的时候,小人就成了动画.源代码如最后所贴,原理性的东西就不多讲,…

    2022年7月24日
    13
  • java sortedset用法_Java SortedSet headSet()用法及代码示例[通俗易懂]

    java sortedset用法_Java SortedSet headSet()用法及代码示例[通俗易懂]Java中的SortedSet接口的headSet()方法用于返回此集合中其元素严格小于参数toElement的部分的视图。此方法返回的集合由该集合支持,因此返回集合中的更改会反映在该集合中,反之亦然。此方法返回的set支持此set支持的所有可选set操作。注意:如果试图插入超出其范围的元素,则此方法返回的集合将引发IllegalArgumentException。用法:SortedSethea…

    2022年8月31日
    6
  • strictmode android,Android StrictMode使用「建议收藏」

    strictmode android,Android StrictMode使用「建议收藏」StrictMode是Android提供的一个开发工具,用于检测一些异常的操作,以便开发者进行修复。StrictMode可以监控以下问题,不应该在应用主线程中完成的工作,包括磁盘读写、网络访问等。内存泄露,包括Activity泄露、SQLite泄露、未正确释放的对象等。使能StrictMode通常在Application和Activity的开始处(如onCreate)添加代码使能StrictMod…

    2022年5月2日
    101
  • phpstorm激活码2021年4月_通用破解码

    phpstorm激活码2021年4月_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    94
  • keras conv(keras中文手册)

    Conv2D:图像空间的2维卷积keras.layers.Conv2D(filters,kernel_size,strides=(1,1),padding=’valid’,data_format=None,dilation_rate=(1,1),activation=None,use_bias=True,kernel_initializer=’glo…

    2022年4月12日
    76
  • mysql和sqlyog安装教程_mysql 全连接

    mysql和sqlyog安装教程_mysql 全连接最近在学java,然后有涉及数据库,老师说是用MySQL,之前学数据库的时候用的是OracleDatabaseExpress11g,不一样,又得搞一次安装。看了很多教程,也踩了很多坑,记录一下。1.下载MySQLInstaller我下载的是MSIInstaller,感觉这个比较快。也可以下载ZIP,看了教程说要添加my.ini文件,改环境变量什么的。好麻烦。看了用MSIInstaller安装的,不用,所以。。MSIInstaller下载链接选择第二个下载选择Nothanks,j

    2025年6月12日
    5

发表回复

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

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