银行家算法c求C语言银行家 算法 "流程图"

银行家算法c  时间:2022-02-23  阅读:()

求C语言银行家 算法 "流程图"

#include<stdio.h> #include<string.h> #include<iostream> #include<stdlib.h> #include<iomanip> #include<conio.h> using namespace std; const int MAX_P=20; const int MAXA=10; //定义A类资源的数量 const int MAXB=5; const int MAXC=7; typedef struct node{ int a; int b; int c; int remain_a; int remain_b; int remain_c; }bank; typedef struct node1{ char name[20]; int a; int b; int c; int need_a; int need_b; int need_c; }process; bank banker; process processes[MAX_P]; int quantity; //初始化函数 void initial() { int i; banker.a=MAXA; banker.b=MAXB; banker.c=MAXC; banker.remain_a=MAXA; banker.remain_b=MAXB; banker.remain_c=MAXC; for(i=0;i<MAX_P;i++){ strcpy(processes[i].name,""); processes[i].a=0; processes[i].b=0; processes[i].c=0; processes[i].need_a=0; processes[i].need_b=0; processes[i].need_c=0; } } //新加作业 void add() { char name[20]; int flag=0; int t; int need_a,need_b,need_c; int i; cout<<endl; cout<<"新加作业"<<endl; cout<<"━━e68a84e79fa5e9819331333236356539━━━━━━━━━━━━━━━━━━━━━━━━━━"<<endl; cout<<"请输入新加作业名:"; cin>>name; for(i=0;i<quantity;i++){ if(!strcmp(processes[i].name,name)){ flag=1; break; } } if(flag){ cout<<"错误,作业已存在"<<endl; } else{ cout<<"本作业所需A类资源:"; cin>>need_a; cout<<"本作业所需B类资源:"; cin>>need_b; cout<<"本作业所需C类资源:"; cin>>need_c; t=1; cout<<need_a<<banker.remain_a; if(need_a>banker.remain_a){ cout<<"错误,所需A类资源大于银行家所剩A类资源"<<endl; t=0; } if(need_b>banker.remain_b){ cout<<"错误,所需B类资源大于银行家所剩B类资源"<<endl; t=0; } if(need_c>banker.remain_c){ cout<<"错误,所需C类资源大于银行家所剩C类资源"<<endl; t=0; } if(t){ strcpy(processes[quantity].name,name); processes[quantity].need_a=need_a; processes[quantity].need_b=need_b; processes[quantity].need_c=need_c; quantity++; cout<<"新加作业成功"<<endl; } else{ cout<<"新加作业失败"<<endl; } } } //为作业申请资源 void bid() { char name[20]; int i,p; int a,b,c; int flag; cout<<endl<<"为作业申请资源"<<endl; cout<<"━━━━━━━━━━━━━━━━━━━━━━━━━━━━"<<endl; cout<<"要申请资源的作业名:"; cin>>name; p=-1; for(i=0;i<quantity;i++){ if(!strcmp(processes[i].name,name)){ p=i; break; } } if(p!=-1){ cout<<"该作业要申请A类资源数量:"; cin>>a; cout<<"该作业要申请B类资源数量:"; cin>>b; cout<<"该作业要申请C类资源数量:"; cin>>c; flag=1; if((a>banker.remain_a)||(a>processes[p].need_a-processes[p].a)){ cout<<"错误,所申请A类资源大于银行家所剩A类资源或该进程还需数量"<<endl; flag=0; } if((b>banker.remain_b)||(b>processes[p].need_b-processes[p].b)){ cout<<"错误,所申请B类资源大于银行家所剩B类资源或该进程还需数量"<<endl; flag=0; } if((c>banker.remain_c)||(c>processes[p].need_c-processes[p].c)){ cout<<"错误,所申请C类资源大于银行家所剩C类资源或该进程还需数量"<<endl; flag=0; } if(flag){ banker.remain_a-=a; banker.remain_b-=b; banker.remain_c-=c; processes[p].a+=a; processes[p].b+=b; processes[p].c+=c; cout<<"为作业申请资源成功"<<endl; } else{ cout<<"为作业申请资源失败"<<endl; } } else{ cout<<"该作业不存在"<<endl; } } //撤消作业 void finished() { char name[20]; int i,p; cout<<endl<<"撤消作业"<<endl; cout<<"━━━━━━━━━━━━━━━━━━━━━━━━━━━━"<<endl; cout<<"要撤消作业名:"; cin>>name; p=-1; for(i=0;i<quantity;i++){ if(!strcmp(processes[i].name,name)){ p=i; break; } } if(p!=-1){ banker.remain_a+=processes[p].a; banker.remain_b+=processes[p].b; banker.remain_c+=processes[p].c; for(i=p;i<quantity-1;i++){ processes[i]=processes[i+1]; } strcpy(processes[quantity-1].name,""); processes[quantity-1].a=0; processes[quantity-1].b=0; processes[quantity-1].c=0; processes[quantity-1].need_a=0; processes[quantity-1].need_b=0; processes[quantity-1].need_c=0; quantity--; cout<<"撤消作业成功"<<endl; } else{ cout<<"撤消作业失败"<<endl; } } //查看资源情况 void view() { int i; cout<<endl<<"查看资源情况"<<endl; cout<<"━━━━━━━━━━━━━━━━━━━━━━━━━━━━"<<endl; cout<<"银行家所剩资源(剩余资源/总共资源)"<<endl; cout<<"A类:"<<banker.remain_a<<"/"<<banker.a; cout<<" B类:"<<banker.remain_b<<"/"<<banker.b; cout<<" C类:"<<banker.remain_c<<"/"<<banker.c; cout<<endl<<endl<<"作业占用情况(已占用资源/所需资源)"<<endl<<endl; if(quantity>0){ for(i=0;i<quantity;i++){ cout<<"作业名:"<<processes[i].name<<endl; cout<<"A类:"<<processes[i].a<<"/"<<processes[i].need_a; cout<<" B类:"<<processes[i].b<<"/"<<processes[i].need_b; cout<<" C类:"<<processes[i].c<<"/"<<processes[i].need_c; cout<<endl; } } else{ cout<<"当前没有作业"<<endl; } } //显示版权信息函数 void version() { cout<<endl<<endl; cout<<" ┏━━━━━━━━━━━━━━━━━━━━━━━┓"<<endl; cout<<" ┃ 银 行 家 算 法 ┃"<<endl; cout<<" ┠———————————————————————┨"<<endl; cout<<" ┃ (c)All Right Reserved Neo ┃"<<endl; cout<<" ┃ sony006@ ┃"<<endl; cout<<" ┃ version 2004 build 1122 ┃"<<endl; cout<<" ┗━━━━━━━━━━━━━━━━━━━━━━━┛"<<endl; cout<<endl<<endl; } int main(void) { int chioce; int flag=1; initial(); version(); while(flag){ cout<<"━━━━━━━━━━━━━━━━━━━━━━━━━━━━"<<endl; cout<<"1.新加作业 2.为作业申请资源 3.撤消作业"<<endl; cout<<"4.查看资源情况 0.退出系统"<<endl; cout<<"请选择:"; cin>>chioce; switch(chioce){ case 1: add(); break; case 2: bid(); break; case 3: finished(); break; case 4: view(); break; case 0: flag=0; break; default: cout<<"选择错误"<<endl<<endl; } } return 0; }

Hosteons:新上1Gbps带宽KVM主机$21/年起,AMD Ryzen CPU+NVMe高性能主机$24/年起_韩国便宜服务器

我们在去年12月分享过Hosteons新上AMD Ryzen9 3900X CPU及DDR4内存、NVMe硬盘的高性能VPS产品的消息,目前商家再次发布了产品更新信息,暂停新开100M带宽KVM套餐,新订单转而升级为新的Budget KVM VPS(SSD)系列,带宽为1Gbps端口,且配置大幅升级,目前100M带宽仅保留OpenVZ架构产品可新订购,所有原有主机不变,用户一直续费一直可用。Bud...

【IT狗】在线ping,在线tcping,路由追踪

IT狗为用户提供 在线ping、在线tcping、在线路由追踪、域名被墙检测、域名被污染检测 等实用工具。【工具地址】https://www.itdog.cn/【工具特色】1、目前同类网站中,在线ping 仅支持1次或少量次数的测试,无法客观的展现目标服务器一段时间的网络状况,IT狗Ping工具可持续的进行一段时间的ping测试,并生成更为直观的网络质量柱状图,让用户更容易掌握服务器在各地区、各线...

注册做什么96%可以干啥,常用的7个常用的国内国外域名注册服务商_云服务器可以干什么

日前,国内知名主机服务商阿里云与国外资深服务器面板Plesk强强联合,推出 阿里云域名注册与备案、服务器ECS购买与登录使用 前言云服务器(Elastic  只需要确定cpu内存与带宽基本上就可以了,对于新手用户来说,我们在购买阿里云服务申请服务器与域名许多云服务商的云服务器配置是弹性的 三周学会小程序第三讲:服务 不过这个国外服务器有点慢,可以考虑国内的ngrokcc。 ngrokcc...

银行家算法c为你推荐
财务系统软件财务管理软件是什么软件instagram电脑版苹果macbook pro做摄影拍照后期有什么优势吗?为什么很多摄影师用它?和thinkpad W系列比呢?webservice框架用JAVA作APP后端,一般用什么web service?用什么restful框架netbios协议现在怎么还有用NetBios协议的,这个协议和TCP/IP协议有什么关系,为什么获取网卡的信息还要网络安全密钥网络安全密钥一般是什么全局钩子delphi 键盘全局钩子怎么查微信注册时间微信号用了多久,怎么知道怎样删除聊天记录怎么批量清除微信聊天记录data什么意思data是什么文件夹可以删除吗cpu仪表盘cpu型号标示数字是什么意思
免费国外空间 看国外视频直播vps 新通用顶级域名 华为云服务 stablehost tier gomezpeer 网通代理服务器 毫秒英文 中国网通测速 申请网站 中国域名 114dns 免费个人网页 广东主机托管 测试网速命令 双十二促销 七十九刀 重庆联通服务器托管 沈阳idc 更多