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


相关推荐

  • 什么是java构造函数_什么是java构造函数

    什么是java构造函数_什么是java构造函数构造函数是面向对象中的一员,构造函数可以叫做构造器,它的函数名与类名相同,不用定义返回值类型,也没有具体的返回值。构造函数是在构建创造时对象时调用函数,作用是可以给对象进行初始化,创建对象都必须要通过构造函数初始化。一个类中如果没有定义过构造函数,那么该类会有一个默认的空参数构造函数。如果在类中定义了指定的构造函数,那么该类中的默认构造函数就没有了。我们人出生的时候,有些人一出生之后再起名字的,但…

    2022年7月8日
    21
  • MongoDb的ConnectionString链接字符串解析

    MongoDb的ConnectionString链接字符串解析MongoDb的ConnectionString链接字符串解析,如下图所示。

    2022年7月12日
    61
  • MATLAB绘制三维地图「建议收藏」

    MATLAB绘制三维地图「建议收藏」1、meshgrid:生成格点矩阵,类似于给定坐标空间[x,y]=meshgrid(1:10);

    2022年10月11日
    1
  • Eclipse汉化教程——只用于学习用途

    Eclipse汉化教程——只用于学习用途Eclipse2019版本汉化教程首先这里我已经做了汉化了,但是不影响各位学习怎么汉化,首先打开工具栏的帮助按钮,选中倒数第四个按钮,如下图所示(看不懂英文的朋友不要紧,对照图上位置即可),如下图所示:然后会打开这个页面然后打开这个网址(默认是英文的)语言包地址(点击左边这个蓝色的字体)出现下面的页面复制图中标记的地址注意官网这个地址中,如果用谷歌浏览器翻译后:号用的是中…

    2022年5月3日
    45
  • navicat premium使用教程详解_navicat premium怎么用

    navicat premium使用教程详解_navicat premium怎么用NavicatPremium基本使用Navicat是一套数据库管理工具,专为简化数据库的管理及降低系统管理成本而设。Navicat是以直觉化的图形用户界面而建的,可以安全和简单地创建、组织、访问并共用信息。NavicatPremium是Navicat的产品成员之一,能简单并快速地在各种数据库系统间传输数据,或传输一份指定SQL格式及编码的纯文本文件。其他功能包括导入向导、导……

    2022年8月20日
    11
  • nfs之端口设置

    nfs之端口设置1,修改/etc/sysconfig/nfs文件  MOUNTD_PORT="4002"STATD_PORT="4003"LOCKD_TCPPORT="4004"LOCKD_UDPPORT="4004"查看rpcinfo-p能看到mouted_port=4002,其余三项未显示2,tcp 1112049端口udp111 4046端口 把…

    2022年6月27日
    32

发表回复

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

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