7-2 银行家算法--申请资源 (30 分)

7-2 银行家算法–申请资源 (30 分)(思路+详解)Come 乖宝宝们

一:前言

这道题需要用到前面的一道题 安全性检查 算法知识,所以强烈建议先看前面那道题
7-1 银行家算法–安全性检查 (20 分)

二:题目

输入N个进程(N<=100),以及M类资源(M<=100),初始化各种资源的总数,T0时刻资源的分配情况。例如: 假定系统中有5个进程{P0,P1,P2,P3,P4}和三类资源{A,B,C},各种资源的数量分别为10、5、7,在T0时刻的资源分配
在这里插入图片描述
输入申请资源的进程以及申请各类资源的数目,判断是否分配。若分配,输出”可以找到安全序列,可以分配。“并输出分配后的系统状态。若不分配,输出”找不到安全序列,不予分配。“并输出当前系统状态。

输入格式:
第一行输入进程数量N,第二行输入资源类数M,第三行输入M类资源个类资源的总数,以下N行分别输入每个进程的名字,该进程对M类资源的最大需求以及已分配资源。最后一行输入申请进程的名字和申请各类资源的数目。

输出格式:
若分配,输出”可以找到安全序列,可以分配。“并输出分配后的系统状态。

若不分配,给出不分配的原因:

1.若输入的进程的名字不正确,输出”查无此进程。“并输出当前系统状态。

2.若申请的资源数目大于最大需求,输出”需求不合理,不予分配。“并输出当前系统状态。

3.若申请的资源数目大于剩余资源,输出”剩余资源不足,不予分配。“并输出当前系统状态。

4.若找不到安全序列,输出”找不到安全序列,不予分配。“并输出当前系统状态。

输入样例1:
在这里给出一组输入。例如:

5
3
10 5 7
P0 7 5 3 0 1 0
P1 3 2 2 2 0 0
P2 9 0 2 3 0 2
P3 2 2 2 2 1 1
P4 4 3 2 0 0 2
P1 1 0 2
结尾无空行

输出样例1:
在这里给出相应的输出。例如:

可以找到安全序列,可以分配。
name max allocation need available
P0 7 5 3 | 0 1 0 | 7 4 3 | 2 3 0
P1 3 2 2 | 3 0 2 | 0 2 0 |
P2 9 0 2 | 3 0 2 | 6 0 0 |
P3 2 2 2 | 2 1 1 | 0 1 1 |
P4 4 3 2 | 0 0 2 | 4 3 0 |
结尾无空行

输入样例2:
在这里给出一组输入。例如:

5
3
10 5 7
P0 7 5 3 0 1 0
P1 3 2 2 2 0 0
P2 9 0 2 3 0 2
P3 2 2 2 2 1 1
P4 4 3 2 0 0 2
P5 1 0 2

结尾无空行
输出样例2:
在这里给出相应的输出。例如:

查无此进程。
name max allocation need available
P0 7 5 3 | 0 1 0 | 7 4 3 | 3 3 2
P1 3 2 2 | 2 0 0 | 1 2 2 |
P2 9 0 2 | 3 0 2 | 6 0 0 |
P3 2 2 2 | 2 1 1 | 0 1 1 |
P4 4 3 2 | 0 0 2 | 4 3 0 |

结尾无空行

三:思路

思路:
1.我相信如果我们AC出来前面安全性检查那到题,那么这道题也会很快做出来
2.前面所求的 need 和 Avaliable是 跟这道题一样的
3.那么接下来我们就是判断 requst 和 need 和 avaliable之间的关系
其中requset 就是 一个进程p1 申请的资源量
1>: 如果这个进程名输入错了 ,那就输出 查无此进程
2>: 如果上诉条件满足,那判断 request 和 Max 关系 request <= Max 就欧克
否则 出输出”需求不合理,不予分配。“并输出当前系统状态。
3>:如果上诉条件满足,那就判断 request 和 avaliable之间的关系 request <= avaliable 就欧克
否则 剩余资源不足,不予分配。“并输出当前系统状态
4>:当上诉条件均满足的话 那么 相应的进程的 allocation 和 need 要做出变化
而且其 系统可利用的资源 avaliable也要做出相应的变化
5>:接下来就是 判断在当前的avaliable下 是否是安全状态,也就是安全性检查
如果找到一条安全序列输出 “可以找到安全序列,可以分配。“并输出分配后的系统状态。
如果找不到就输出”找不到安全序列,不予分配。“并输出当前系统状态。

四:坑

需要注意的是当资源分配完成后,如果找不到安全序列的话,那么需要注意的是:
将分配给该进程的资源给收回来 也就是 该进程的need 和 allocation回到 原来的值 同时 还有 avaliable也需要回归到原来的值

五:上码:

/**思路:1.我相信如果我们AC出来前面安全性检查那到题,那么这道题也会很快做出来2.前面所求的 need 和 Avaliable是 跟这道题一样的3.那么接下来我们就是判断 requst 和 need 和 avaliable之间的关系其中requset 就是 一个进程p1 申请的资源量 1>: 如果这个进程名输入错了 ,那就输出 查无此进程2>: 如果上诉条件满足,那判断 request 和 Max 关系 request <= Max 就欧克否则 出输出”需求不合理,不予分配。“并输出当前系统状态。 3>:如果上诉条件满足,那就判断 request 和 avaliable之间的关系 request <= avaliable 就欧克否则 剩余资源不足,不予分配。“并输出当前系统状态4>:当上诉条件均满足的话 那么 相应的进程的 allocation 和 need 要做出变化而且其 系统可利用的资源 avaliable也要做出相应的变化5>:接下来就是 判断在当前的avaliable下  是否是安全状态,也就是安全性检查如果找到一条安全序列输出 “可以找到安全序列,可以分配。“并输出分配后的系统状态。			 如果找不到就输出”找不到安全序列,不予分配。“并输出当前系统状态。 
**/#include<bits/stdc++.h>
using namespace std;int N,M;
string str;
vector<int>v1;//用于存放各种的资源总量 
vector<int>v2;//用于代表申请资源的进程申请的  资源量 
vector<int>v3;//用于记录最初的avaliable struct Node{string processName; int a[100];//Maxint b[100];//allocation int c[100];//needbool finish;
} node[1000];//用于判断是否有该进程
bool judgeExit(string str){for(int i = 0; i < N; i++){if(str == node[i].processName){return true;}}return false;
}//用于计算此时的request 和 need
bool requestNeed(){int count  = 0;for(int i = 0;  i < N; i++){int count = 0;if(str == node[i].processName){for(int j = 0;  j < M; j++){if(v2[j] <= node[i].c[j]){//请求量 小于 need count++;}}			}if(count == M){return true;}}return false;}  
//用判断申请的资源数目是否大于剩余资源 
bool requestAvaliable(){int count  = 0;for(int j = 0; j < M; j++){if(v2[j] <= v1[j]){ //请求量 小于 avaliabale count++;}}			if(count == M){return true;}return false;}//判断当前的安全状态
bool isSafe(){int cnt = 0;	for(int i = 0; i < N; i++){int count = 0;for(int j = 0; j < M; j++){if(node[i].c[j] <= v1[j]){count++;}else{break;//只要有一个不合适就 break 出去 }				}if(node[i].finish == false && count == M) {//count == M说明剩余的各个资源总量大于该进程的所需要的 for(int j = 0; j < M; j++){v1[j] += node[i].b[j];//那么此时剩余的资源总量为原来的加上 该进程释放其占有的资源}	node[i].finish = true; cnt++;//记录完成进程的个数 //	cout << node[i].processName << ' ';//此处牛逼之处在于 只要我们找到满足条件的就从-1开始继续寻找满足条件的 i = -1; }					}if(cnt == N){return true;}return false;
} //用于输出此时系统的状态 
void state(){int flag = 0;cout << "name max allocation need available" << endl;for(int i = 0; i < N; i++){cout << node[i].processName << ' ';for(int j = 0; j < M; j++){cout << node[i].a[j] << ' ';			}			cout << "| ";for(int j = 0; j < M; j++){cout << node[i].b[j] << ' ';			}cout << "| ";for(int j = 0; j < M; j++){cout << node[i].c[j] << ' ';			}cout << "|";if(flag == 0){for(int j = 0; j < M; j++){if(j == 0)cout << ' ' <<v3[j];elsecout << ' ' <<v3[j] ;				 			}	flag = 1;		}	cout << endl;	}
}int main(){cin >> N >> M;for(int i = 0; i < M; i++){int nums;cin >> nums;v1.push_back(nums);	} for(int i = 0; i < N; i++){cin >> node[i].processName;//输入Max for(int j = 0; j < M; j++){cin >> node[i].a[j]; }//输入allovation  for(int j = 0; j < M; j++){cin >> node[i].b[j];v1[j] -= node[i].b[j];//这里是每次减去分配的资源 那么剩下的最后就是  available }//计算needfor(int j = 0; j < M; j++){node[i].c[j] = node[i].a[j] - node[i].b[j];} node[i].finish = false;}cin >> str;for(int i = 0; i < M; i++){int temp;cin >> temp;v2.push_back(temp);} //将最初的avaliable记录下来 for(int i = 0; i < M; i++){v3.push_back(v1[i]);} if(judgeExit(str) == false){cout << "查无此进程。" << endl;state();}else if(requestNeed() == false){cout << "需求不合理,不予分配。" << endl;state();}else if(requestAvaliable() == false) {cout << "剩余资源不足,不予分配。" << endl;state();}//此时开始将申请的资源赋值给该进程同时进行安全检测 else if(judgeExit(str) == true && requestNeed() == true && requestAvaliable() == true){for(int i = 0; i < N; i++){if(str == node[i].processName){for(int j = 0; j < M; j++){node[i].b[j] += v2[j];//这里是更新 该进程的allocation node[i].c[j] -= v2[j];//这里是更新 该进程的needv1[j] -= v2[j]; //这里是更新 该进程的avaliable v3[j] -= v2[j];//存放 最初 avaliable的	}}	 		} if(isSafe() == true){cout << "可以找到安全序列,可以分配。" << endl;state();}else{cout << "找不到安全序列,不予分配。" << endl;//如果不满足条件的话 需要将原来 进程的的资源分配形式输出来 for(int i = 0; i < N; i++){if(str == node[i].processName){for(int j = 0; j < M; j++){node[i].b[j] -= v2[j];//这里是更新 该进程的allocation node[i].c[j] += v2[j];//这里是更新 该进程的needv1[j] += v2[j]; //这里是更新 该进程的avaliable v3[j] += v2[j];//存放 最初 avaliable的	}}	 		} state();} }} //5
//3
//10 5 7
//P0 7 5 3 0 1 0
//P1 3 2 2 2 0 0
//P2 9 0 2 3 0 2
//P3 2 2 2 2 1 1
//P4 4 3 2 0 0 2
//P1 2 2 2//name max allocation need available
//P0 7 5 3 | 0 1 0 | 7 4 3 | 3 3 2
//P1 3 2 2 | 2 0 0 | 1 2 2 |
//P2 9 0 2 | 3 0 2 | 6 0 0 |
//P3 2 2 2 | 2 1 1 | 0 1 1 |
//P4 4 3 2 | 0 0 2 | 4 3 0 |
//找到安全序列,处于安全状态。//5
//3
//10 5 7
//P0 7 5 3 0 1 0
//P1 3 2 2 2 0 0
//P2 9 0 2 3 0 2
//P3 2 2 2 2 1 1
//P4 4 3 2 0 0 2
//P0 0 1 0

在这里插入图片描述
宝宝们 加油呀 我们共勉 活得坦然 走的自信 坚持热爱 不负初心!!!!!!!!!!!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308141.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

年薪100万和10万程序员的差距

点击蓝字关注&#xff0c;回复“职场进阶”获取职场进阶精品资料一份我们看武侠大片&#xff0c;经常有那种本来可以练就绝世武功的大虾。阴差阳错练的走火入魔。一开始还可以硬撑&#xff0c;还能打败一些虾兵蟹将。遇见真正的高手&#xff0c;这些大虾们立马就败下阵来。其实…

7-3 银行家算法--综合 (50 分)(思路+详解+分析输入)宝宝们 加油

一&#xff1a;前言 这道题涉及到 银行家算法的申请资源 算法 还有 安全性检查的耍算法 那么强烈建议 把前面的学完再看本题 7-1 银行家算法–安全性检查 (20 分) 7-2 银行家算法–申请资源 (30 分) 二&#xff1a;题目 输入N个进程(N<100)&#xff0c;以及M类资源&#…

如何在龙芯3B4000上部署基于.Net Core 开发的物联网平台IoTSharp

今天很开心的拿到了龙芯的测试服务器账号&#xff0c; 先上图show一下&#xff0c; 双核&#xff0c; 8G内存&#xff0c; 50G硬盘。架构 mips64el 登录后&#xff0c; 显示为 uos 及其网址信息:接下来&#xff0c; 二话不说&#xff0c; 我们开始下载龙芯版的.Net Core &#…

46. 全排列015(回溯法求解)

一:题目 示例 1&#xff1a; 输入&#xff1a;nums [1,2,3] 输出&#xff1a;[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]] 示例 2&#xff1a;输入&#xff1a;nums [0,1] 输出&#xff1a;[[0,1],[1,0]] 示例 3&#xff1a;输入&#xff1a;nums [1] 输出&#xf…

git did not exit cleanly(解决办法)

一&#xff1a;问题描述 我们在push的时候&#xff0c;出现如下问题 这个图是我拿别人的&#xff08;因为我的问题解决后 没保存图&#xff09; 二:解决 1.新建一个仓库在gitee上: 2:将新建的仓库克隆到本地 3&#xff1a;将原来的文件剪切到javanew(新建的仓库) 4&#…

[Hei.Captcha] Asp.Net Core 跨平台验证码实现

&#xfeff;&#xfeff;写在前面说起来比较丢脸。我们有个手机的验证码发送逻辑需要使用验证码&#xff0c;这块本来项目里面就有验证码绘制逻辑&#xff0c;.Net Framework的&#xff0c;使用的包是System.Drawing,我把这验证码绘制逻辑复制到.Net Core的新项目引用对比包Sy…

77. 组合016(回溯法)

一:题目 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 示例 1&#xff1a; 输入&#xff1a;n 4, k 2 输出&#xff1a; [[2,4],[3,4],[2,3],[1,2],[1,3],[1,4], ] 示例 2&#xff1a;输入&#xff1a;n …

.NET5即至,你准备好了吗?

.NET 5.0 Preview7是RC版前倒数第二个预览版&#xff0c;发布至今恰好一个月&#xff0c;算起来&#xff0c;.NET Core开源已经4年了&#xff0c;然而在互联网大型系统开发中很多环节都还是空白的&#xff0c;造轮子诚非一日之功&#xff01;这里为大家推荐一个分布式日志分析解…

216. 组合总和 III017(回溯法求解)

一&#xff1a;题目 二:思路 1.总体来看这是一个解空间为k层的排列树 第一层为1~9 2.递归函数的参数和返回值 1>:返回值&#xff1a;vector<vector > res 每次的求解结果&#xff1a;vector path 2>:参数&#xff1a; backtacking(int k,int n,int index,int sum)…

基于IdentityServer4的OIDC实现单点登录(SSO)原理简析

&#xfeff;&#xfeff;# 写在前面IdentityServer4的学习断断续续&#xff0c;兜兜转转&#xff0c;走了不少弯路&#xff0c;也花了不少时间。可能是因为没有阅读源码&#xff0c;也没有特别系统的学习资料&#xff0c;相关文章很多园子里的大佬都有涉及&#xff0c;有系列文…

fc协议有哪些数据传输服务器,FC协议详解

FC协议简介开发于1988年&#xff0c;最早是用来提高硬盘协议的传输带宽&#xff0c;侧重于数据的快速、高效、可靠传输。到上世纪90年代末&#xff0c;FCSAN开始得到大规模的广泛应用。FC协议其实并不能翻译成光纤协议&#xff0c;只是FC协议普遍采用光纤作为传输线缆而不是铜缆…

51. N 皇后018(回溯法求解)

一&#xff1a;题目 二:思路 思路: 1.这里在选择建树(也就是在选择解的空间上)是 子集树 2.那么在结点上我们选择的是一个二维的矩阵就是将最后的结果落实到一个二维容器里 也就遍历到叶节点时候一种可行解的情况 3.写码思路&#xff1a; <1>:递归函数的参数: backtacki…

小姐姐为你解析马爸爸是怎么用大数据“宰你”的

一、首先大数据杀熟是什么&#xff1f;大数据杀熟本质就是一种数据营销手段&#xff1a;商家为了追求商业目的&#xff0c;利用交易双方信息的不对称性&#xff0c;根据每个用户的身份信息和历史数据表现&#xff0c;或者根据用户当前的需求来调整产品定价的手段 &#xff1b;比…

苹果手机上没有显示订阅服务器,手机里没有订阅的选项,我该怎样取消自动收费项目...

有些应用和服务会在用户订阅后提供内容访问权限。与购买单个项目(例如宝石和金币等游戏币)不同&#xff0c;在您选择结束订阅之前&#xff0c;订阅会自动续订。自动续订的订阅包括&#xff1a;Apple Music 订阅Apple 新闻、报纸和杂志订阅内容或服务的 App 内订阅(HBO NOW、Spo…

7-4 N皇后 (28 分)(思路+详解)

一&#xff1a;题目 Come 宝&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 在N*N的方格棋盘放置了N个皇后&#xff0c;使得它们不相互攻击&#xff08;即任意2个皇后不…

内存不够用还要速度快,终于找到可以基于 File 的 Cache 了

一&#xff1a;背景1. 讲故事18年的时候在做纯内存项目的过程中遇到了这么一个问题&#xff0c;因为一些核心数据都是飘在内存中&#xff0c;所以内存空间对我们来说额外宝贵&#xff0c;但偏偏项目中有些数据需要缓存&#xff0c;比如说需要下钻的报表上的点&#xff0c;基于性…

计算机网络:如何传输一条数据(详解)

一&#xff1a;不同的localhost如何传送信息 1:图示概览图 (1):无注解 (2):有注解 这里我在这个线路层中又连了一些新的 sw 和 router 其实还可以连更多&#xff0c;相当于一个网状的 注意同一个网络中只有一个网关&#xff0c;形象点理解网关就是通往别的网洛的大门 在下方…

为什么我们需要Logstash,Fluentd等日志摄取器?

前文传送门&#xff1a;如何利用NLog输出结构化日志&#xff0c;并在Kibana优雅分析日志&#xff1f;疑问&#xff1a;既然应用能直接向ElasticSearch写日志&#xff0c;为什么我们还需要Logstash,Fluentd等日志摄取器&#xff1f;而且这些日志摄取器组件还成为日志收集的事实标…

7-1 装载问题 (10 分)(思路+详解)

一&#xff1a;题目 Come 宝宝&#xff01;&#xff01; 输出格式: 输出所有可行的方案数量 输入样例1: 3 50 50 10 40 40结尾无空行 输出样例1: 4结尾无空行 输入样例2: 3 50 50 20 40 40结尾无空行 输出样例2: 0二:思路 1.这个解的空间选择的是子集树 2.递归函数参数 b…

程序员是终身学习的职业,应该怎么学习?

在上一篇《一款用了就不想走的工具》中介绍了一款工具 Notion &#xff0c;可以做学习的规划、时间的管理、学习的记录等&#xff0c;但学习本身还是需要一些方法的&#xff0c;本文谈谈我对学习的一些感悟。不管你是刚刚进入职场的新人&#xff0c;还是工作多年的老兵&#xf…