成人午夜淫片100集 I 亚洲小视频在线观看,com I 一级片特级片 I 丁香五月欧美成人 I 男插女网站 I 手机看片日韩国产 I 欧美96在线 | 欧 I 黄色影片在线看 I 久久精美日产二线三线 I 久久一级精品视频 I 亚洲福利视 I 免播放器亚洲 I 欧美日韩精品电影 I 性做久久久久久久 I 国产超碰人人 I 91porny九色视频 I 日韩电影中文,亚洲精品乱码 I 亚洲男女视频 I 黄色av一区二区 I 美女国产视频 I 91日韩精品一区二区三区 I 蜜桃臀av网站 I 99久久久99久久国产片鸭王 I 色吧亚洲日本 I 日本高清www色视频 I aa黄色片 I 91激情视频在线 I 麻豆综合在线

綜合百科

銀行家算法代碼

2025-01-05 09:56:02 來源:互聯網轉載或整理

銀行家算法是一種最有代表性的避免死鎖的算法。在避免死鎖方法中允許進程動態地申請資源,但系統在進行資源分配之前,應先計算此次分配資源的安全性,若分配不會導致系統進入不安全狀態,則分配,否則等待。為實現銀行家算法,系統必須設置若干數據結構。

銀行家算法程序代碼如下:

#include<string.h>

#include<stdio.h>

#include<iostream.h>

#defineFALSE0

#defineTRUE1

#defineW10

#defineR10

intM;//總進程數

intN;//資源種類

intALL_RESOURCE[W];//各種資源的數目總和

intMAX[W][R];//M個進程對N類資源最大資源需求量

intAVAILABLE[R];//系統可用資源數

intALLOCATION[W][R];//M個進程已經得到N類資源的資源量

intNEED[W][R];//M個進程還需要N類資源的資源量

intRequest[R];//請求資源個數

voidoutput()

{

inti,j;

cout<<endl<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<"各種資源的總數量:"<<endl;

for(j=0;j<N;j++)

cout<<"資源"<<j<<":"<<ALL_RESOURCE[j];

cout<<endl;

cout<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<"目前各種資源可利用的數量為:"<<endl;

for(j=0;j<N;j++)

cout<<"資源"<<j<<":"<<AVAILABLE[j];

cout<<endl;

cout<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<"各進程還需要的資源數量:"<<endl<<endl;

for(i=0;i<N;i++)

cout<<"資源"<<i;

cout<<endl;

for(i=0;i<M;i++)

{
cout<<"進程"<<i<<":";

for(j=0;j<N;j++)

cout<<NEED[i][j]<<"";

cout<<endl;

}

cout<<endl;

cout<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<"各進程已經得到的資源量:"<<endl<<endl;

for(i=0;i<N;i++)

cout<<"資源"<<i;

cout<<endl;

for(i=0;i<M;i++)

{
cout<<"進程"<<i<<":";

for(j=0;j<N;j++)

cout<<ALLOCATION[i][j]<<"";

cout<<endl;

}

cout<<endl;

}

voiddistribute(intk)

{

intj;

for(j=0;j<N;j++)

{

AVAILABLE[j]=AVAILABLE[j]-Request[j];

ALLOCATION[k][j]=ALLOCATION[k][j]+Request[j];

NEED[k][j]=NEED[k][j]-Request[j];

}

}

voidrestore(intk)

{

intj;

for(j=0;j<N;j++)

{

AVAILABLE[j]=AVAILABLE[j]+Request[j];

ALLOCATION[k][j]=ALLOCATION[k][j]-Request[j];

NEED[k][j]=NEED[k][j]+Request[j];

}

}

intcheck()

{

intWORK[R],FINISH[W];

inti,j;

for(j=0;j<N;j++)WORK[j]=AVAILABLE[j];

for(i=0;i<M;i++)FINISH[i]=FALSE;

for(i=0;i<M;i++)

{

for(j=0;j<N;j++)

{

if(FINISH[i]==FALSE&&NEED[i][j]<=WORK[j])

{

WORK[j]=WORK[i]+ALLOCATION[i][j];

}

}

FINISH[i]=TRUE;

}

for(i=0;i<M;i++)

{

if(FINISH[i]==FALSE)

{

cout<<endl;

cout<<"系統不安全!!!本次資源申請不成功!!!"<<endl;

cout<<endl;

return1;

}

else

{

cout<<endl;

cout<<"經安全性檢查,系統安全,本次分配成功。"<<endl;

cout<<endl;

return0;

}

}

}

voidbank()//銀行家算法

{

inti=0,j=0;

charflag='Y';

while(flag=='Y'||flag=='y')

{

i=-1;

while(i<0||i>=M)

{

cout<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<endl<<"請輸入需申請資源的進程號:";

cin>>i;

if(i<0||i>=M)cout<<"輸入的進程號不存在,重新輸入!"<<endl;

}

cout<<"請輸入進程"<<i<<"申請各類資源的數量:"<<endl;

for(j=0;j<N;j++)

{
cout<<"資源"<<j<<":";

cin>>Request[j];

if(Request[j]>NEED[i][j])//若請求的資源數大于進程還需要i類資源的資源量j

{

cout<<endl<<"進程"<<i<<"申請的資源數大于進程"<<i<<"還需要"<<j<<"類資源的數量!";
cout<<"若繼續執行系統將處于不安全狀態!"<<endl;

flag='N';

break;

}

else

{

if(Request[j]>AVAILABLE[j])//若請求的資源數大于可用資源數

{

cout<<endl<<"進程"<<i<<"申請的資源數大于系統可用"<<j<<"類資源的數量!";

cout<<"若繼續執行系統將處于不安全狀態!"<<endl;

flag='N';

break;

}

}

}

if(flag=='Y'||flag=='y')

{

distribute(i);//調用change(i)函數,改變資源數

if(check())//若系統安全

{

restore(i);//調用restore(i)函數,恢復資源數

output();//輸出資源分配情況

}

else//若系統不安全

output();//輸出資源分配情況

}

else//若flag=N||flag=n

cout<<endl;

cout<<"是否繼續銀行家算法演示,按'Y'或'y'鍵繼續,按'N'或'n'鍵退出演示:";

cin>>flag;

}

}

voidversion()

{

cout<<endl;

cout<<"\t 銀行家算法  "<<endl;

}

voidmain()//主函數

{

inti=0,j=0,p;

version();

getchar();

cout<<endl<<"請輸入總進程數:";

cin>>M;

cout<<endl<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<"請輸入總資源種類:";

cin>>N;

cout<<endl<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<"請輸入各類資源總數:(需要輸入數為"<<N<<"個)";

for(i=0;i<N;i++)

cin>>ALL_RESOURCE[i];

cout<<endl<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<"輸入各進程所需要的各類資源的最大數量:(需要輸入數為"<<M*N<<"個)";

for(i=0;i<M;i++)

{

for(j=0;j<N;j++)

{

do

{

cin>>MAX[i][j];

if(MAX[i][j]>ALL_RESOURCE[j])

cout<<endl<<"占有資源超過了聲明的該資源總數,請重新輸入"<<endl;

}

while(MAX[i][j]>ALL_RESOURCE[j]);

}

}

cout<<endl<<"━━━━━━━━━━━━━━━━━━"<<endl;

cout<<"輸入各進程已經占據的各類資源的數量:(需要輸入數為"<<M

*N<<"個)";

for(i=0;i<M;i++)

{

for(j=0;j<N;j++)

{

do

{

cin>>ALLOCATION[i][j];

if(ALLOCATION[i][j]>MAX[i][j])

cout<<endl<<"占有資源超過了聲明的最大資源,請重新輸入"<<endl;

}

while(ALLOCATION[i][j]>MAX[i][j]);

}

}

for(j=0;j<N;j++)//初始化資源數量

{

p=ALL_RESOURCE[j];

for(i=0;i<M;i++)

{

p=p-ALLOCATION[i][j];//減去已經被占據的資源

AVAILABLE[j]=p;

if(AVAILABLE[j]<0)

AVAILABLE[j]=0;

}

}

for(i=0;i<M;i++)

for(j=0;j<N;j++)

NEED[i][j]=MAX[i][j]-ALLOCATION[i][j];

output();

bank();

}

本文標簽: 存款基準利率2019

其他文章

  • 阜新銀行存款安全嗎 阜新銀行安全嗎
  • 錳酸鋰上市龍頭 錳酸鋰股票的簡要分析
  • 海南礦業為什么不漲 海南礦業股票為什么不漲
  • 中華保險是大公司嗎 中華保險公司規模怎么樣
  • 590002分過紅嗎 中郵核心增長股票基金有分過紅嗎
  • 商貸轉公積金麻煩嗎 商轉公的流程有哪些呢
  • 完全不懂基金怎么入門 基金入門的方法
  • 豬肉行業龍頭股一覽表 豬肉行業股票的簡要分析
  • 人民幣的單位換算 人民幣有什么單位
  • 央企有哪些 央企的主要內容
  • 2022年電影推薦豆瓣9分以上(豆瓣高分電影盤點排行榜)
  • 好記星M16上市時間和價格(M16刷機教程)
  • 米迦勒和路西法誰厲害(路西法為什么對米迦勒不好)
  • 勞榮枝是拍抖音被發現的嗎(勞榮枝為什么到現在才被發現)
  • 列寧的遺體保留在哪里(遺體只剩10%維護費高達百萬)
  • 梁海玲怎么慘死家中的(究竟因何殞命)
  • 法國安盛保險公司(1816建立)(世界上歷史最悠久的保險公司)
  • 高鐵乘務員工資待遇如何(列車員工資多少錢一個月)
  • 冬奧會歷屆獎牌排行榜(歷屆冬奧會各國獎牌排行榜)
  • 歷屆好聲音十強排名(前十季中國好聲音冠軍名單)
  • 黔ICP備19002813號

    主站蜘蛛池模板: 久久九九日本韩国精品 | 亚洲欧美国产双大乳头 | 欧美精品久久久久久久自慰 | 中文无码精品a∨在线观看不卡 | 欧美性猛交xxxx黑人猛交 | 中文在线а天堂中文在线新版 | 精品熟女少妇av久久免费软件 | 欧美日韩在线视频一区 | 久草热8精品视频在线观看 99视频精品全部在线观看 | 久久久日韩精品一区二区 | 人人妻人人澡人人爽曰本 | 三叶草欧洲码在线 | 午夜人妻久久久久久久久 | 亚洲色成人网站www永久 | 色综合天天综合网国产成人网 | 在线中文字幕国产一区 | 成人午夜精品无码区久久 | 少妇粗大进出白浆嘿嘿视频 | 欧美日韩一卡2卡三卡4卡 乱码欧美孕交 | 青青小草av一区二区三区 | 九九影院理论片私人影院 | 久久精品中文騷妇女内射 | 天天鲁在视频在线观看 | 国产福利一区二区三区在线视频 | 强行无套内谢大学生初次 | 不卡一卡二卡三乱码免费网站 | 久久久久人妻一区二区三区 | 自拍区偷拍亚图片小说 | 成人欧美一区二区三区黑人 | 国产精品一区二区av片 | 欧美午夜一区二区福利视频 | 久久精品人妻一区二区三区 | 久久蜜桃亚洲一区二区 | 亚洲国产综合精品 在线 一区 | 亚洲国产中文在线二区三区免 | 无码专区一va亚洲v专区在线 | 伊人久久大线影院首页 | 97色偷偷色噜噜狠狠爱网站 | 乱中年女人伦av一区二区 | 欧美午夜精品一区二区蜜桃 | 18成禁人视频免费 |