#include <iostream>
 #include<string>
 #define False 0
 #define True 1

 using namespace std;

 ] = {  };       //系统->拥有资源
 ][] = {  };        //进程->共需要
 ][] = {  }; //进程->已得到
 ][] = {  };       //进程->还需要

 ] = {  };            //模拟->系统->拥有资源
 //int Request[100] = { 0 };         //进程->请求资源   0.0貌似后来没用到

 ] = {  };           //资源名称。界面使用

 ] = {  };            //存放安全序列

 ;                      //进程的最大数为
 ;                      //资源的最大数为

 void showdata();                  //显示资源矩阵
 int safe();                       //安全性算法

 int main()//主函数
 {
     , m, n, flag;
     char ming;

     //------------------------------------------------------------->>>>>>>>   【界面】    >>>
     cout << "\t*-----------------------------------------------------*" << endl;
     cout << "\t||                                                   ||" << endl;
     cout << "\t||              银行家算法实现                       ||" << endl;
     cout << "\t||                                                   ||" << endl;
     cout << "\t||                                    张金棒         ||" << endl;
     cout << "\t||                                                   ||" << endl;
     cout << "\t||                                  2016.06.29       ||" << endl;
     cout << "\t||                                                   ||" << endl;
     cout << "\t*-----------------------------------------------------*" << endl;

     //------------------------------------------------------------->>>>>>>>   【初始化】    >>>
     cout << "请先输入系统可供资源种类的数量:";
     cin >> n;
     N = n;

     ; i < n; i++)
     {
         cout <<  << "的名称:";
         cin >> ming;
         name[i] = ming;
         cout << "资源的数量:";
         cin >> number;
         Avaliable[i] = number;
     }
     cout << endl;
     cout << "请输入作业的数量";
     cin >> m;
     M = m;
     cout << "请输入各进程的最大需求量(" << m << "*" << n << "矩阵)[Max]:" << endl;
     ; i < m; i++)
         ; j < n; j++)
             cin >> Max[i][j];
     do
     {
         flag = ;
         cout << "请输入各进程已经申请的资源量(" << m << "*" << n << "矩阵)[Allocation]:" << endl;
         ; i < m; i++)
             ; j < n; j++)
             {
                 cin >> Allocation[i][j];
                 ;
                 Need[i][j] = Max[i][j] - Allocation[i][j];
                 Avaliable[j] = Avaliable[j] - Allocation[i][j];
             }
         if (flag)
             cout << "申请的资源大于最大需求值,请重新输入!\n";
     } while (flag);

     showdata();//显示各种资源

     safe();//用银行家算法判定系统是否安全
     system("pause");
     ;
 }

 //------------------------------------------------------------->>>>>>>>   【界面·显示资源矩阵】    >>>
 void showdata()
 {
     int i, j;
     cout << "系统当前可用资源[Avaliable]:" << endl;
     ; i < N; i++)
         cout << name[i] << " ";
     cout << endl;
     ; j < N; j++)
         cout << Avaliable[j]<<" ";
     cout << endl;
     cout << "           Max        Allocation        Need" << endl;
     cout << "process   ";
     ; j < ; j++)
     {
         ; i < N; i++)
             cout << name[i] << " ";
         cout << "        ";
     }
     cout << endl;
     ; i < M; i++)
     {
         cout << " " << i << "        ";
         ; j < N; j++)
             cout << Max[i][j] << " ";
         cout << "        ";
         ; j < N; j++)
             cout << Allocation[i][j] << " ";
         cout << "        ";
         ; j < N; j++)
             cout << Need[i][j] << " ";
         cout << endl;
     }
 }
 //------------------------------------------------------------->>>>>>>>   【银行家算法】    >>>
 int safe()
 {
     , m, apply, Finish[] = {  };  //apply [应用,使用]
     int j;
     ; i < N; i++)
     {
         Work[i] = Avaliable[i];
     }
     ; i < M; i++)//------------------------------------->>>>>>>>>>选定进程  i
     {
         apply = ;
         ; j < N; j++)//--------------------------------->>>>>>>>>>选定资源  j
         {
             if (Finish[i] == False&&Need[i][j] <= Work[j])//------>>>>>>>>>>第i个进程j类所需资源小于系统拥有的资源
             {
                 apply++;
                 if (apply == N)//--------------------------------->>>>>>>>>>当i进程各类资源都满足后
                 {
                     ; m < N; m++)
                         Work[m] = Work[m] + Allocation[i][m];//--->>>>>>>>>>分配其资源使其运行结束然后回收资源
                     Finish[i] = True;//--------------------------->>>>>>>>>>i进程执行完毕
                     temp[k] = i;//-------------------------------->>>>>>>>>>写入进程号到序列中
                     i = -;//------------------------------------->>>>>>>>>>检查前面的是否有可满足的
                     k++;//---------------------------------------->>>>>>>>>>准备好写下一个安全序列项
                 }
             }
         }
     }
     ; i < M; i++)
     {
         if (Finish[i] == False)
         {
             cout << "系统不安全" << endl;//不成功 系统不安全
             ;
         }
     }
     cout << "系统是安全的!" << endl;//如果安全,输出成功
     cout << "分配的序列:";
     ; i < M; i++) //输出运行进程的数组
     {
         cout << temp[i];
         ) cout << "->";
     }
     cout << endl;
     ;
 }

c++银行家算法的更多相关文章

  1. c/c++多线程模拟系统资源分配(并通过银行家算法避免死锁产生)

    银行家算法数据结构 (1)可利用资源向量Available 是个含有m个元素的数组,其中的每一个元素代表一类可利用的资源数目.如果Available[j]=K,则表示系统中现有Rj类资源K个. (2) ...

  2. Round() 四舍五入 js银行家算法(转)

    首先问一下round(0.825,2) 返回的结果,大家猜一猜, 首先SQL server 返回的是 0.83 js的返回结果 是0.83,code 如下: var b = 0.825;        ...

  3. 银行家算法java实现

    关于银行家算法的理论知识,课本或者百度上有好多资料,我就不再多说了,这里把我最近写的银行家算法的实现带码贴出来. 由于这是我们的一个实验,对系统资源数和进程数都指定了,所以这里也将其指定了,其中系统资 ...

  4. 操作系统,银行家算法模拟实现(Windows 环境 C++)

    计算机操作系统课设需要,写了两个下午的银行家算法(陷在bug里出不来耽误了很多时间),参考计算机操作系统(汤子瀛) 实现过程中不涉及难度较大的算法,仅根据银行家算法的思想和步骤进行实现.以下为详细步骤 ...

  5. 银行家算法C++程序

    此程序在Windows10    CodeBlocks17.12环境下测试运行,其他编程环境未经测试! 作业需求↓↓↓↓↓↓ 运行效果图如下 (codeblocks下载地址http://www.cod ...

  6. python模拟银行家算法

    前言: 大二第一学期学习了操作系统,期末实验课题要求模拟算法.遂根据自己学习的python写下此文.以此锻炼自己编码能力.虽说是重复造轮子,但还是自己的思路体现 代码及注释如下(银行家算法不再赘述): ...

  7. 预防和避免死锁的方法及银行家算法的java简单实现

    预防死锁 (1) 摒弃"请求和保持"条件 基本思想:规定所有进程在开始运行之前,要么获得所需的所有资源,要么一个都不分配给它,直到所需资源全部满足才一次性分配给它. 优点:简单.易 ...

  8. Round() 四舍五入 js银行家算法

    首先问一下round(0.825,2) 返回的结果,大家猜一猜, 首先SQL server 返回的是 0.83 js的返回结果 是0.83,code 如下: var b = 0.825;        ...

  9. C程序模拟实现银行家算法

    C程序模拟实现银行家算法 上周又做操作系统实验,题目是用程序模拟实现银行家算法,写了半天还真有点晕,主要是因为想尽可能符合课本上的描述,所以写出来的程序就比较恶心了,好了,银行家算法就不多说了,不了解 ...

随机推荐

  1. Spring Security 入门(1-4-1)Spring Security - 认证过程

    理解时可结合一下这位老兄的文章:http://www.importnew.com/20612.html 1.Spring Security的认证过程 1.1.登录过程 - 如果用户直接访问登录页面 用 ...

  2. Error loading MySQLdb module: No module named 'MySQLdb'----------- django成功连接mysql数据库的方法

    在进行django学习过程中,尝试使用框架连接mysql数据库,启动服务器的时候经常遇到Error loading MySQLdb module: No module named 'MySQLdb' ...

  3. leetcode算法:Trim a Binar Search Tree

    Given a binary search tree and the lowest and highest boundaries as L and R, trim the tree so that a ...

  4. IIS进行URL重写

    一.Why? 1.先来讲一讲为什么我们要使用url重写这个东西 2.因为我学习的后端是nodejs,然后我发现nodejs一个非常让人难受的事,就是它监听端口不是80和443时,你访问网页需要输入端口 ...

  5. MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)

    本节演示如何为 MySQL 数据库提供持久化存储,步骤为: 创建 PV 和 PVC. 部署 MySQL. 向 MySQL 添加数据. 模拟节点宕机故障,Kubernetes 将 MySQL 自动迁移到 ...

  6. html标记语言 --表单

    html标记语言 --表单 七.表单 1.表单标记 1.1表单中的内容 <form></form>定义表单的开始位置和结束位置,表单提交时的内容就是<form>表单 ...

  7. Flume报 Space for commit to queue couldn't be acquired. Sinks are likely not keeping up with sources, or the buffer size is too tight

    报这个错误 需要一个是flume堆内存不够.还有一个就是把channel的容器调大 在channel加配置 type - 组件类型名称必须是memory capacity 100 存储在 Channe ...

  8. fiddler实现手机抓包

    对fiddler相关配置 1.允许fiddler捕获http协议,打开fiddler客户端,菜单框选择Tools->Options->HTTPS,勾选图中三项 2.允许远程连接,Tools ...

  9. 自动化运维:使用flask+mysql+highcharts搭建监控平台

    1.前言 本来想做一个比较完善的监控平台,只需要做少许改动就可以直接拿来用,但是在做的过程中发现要实现这个目标所需的工作量太大,而当前的工作中对其需求又不是特别明显.所以就退而求其次,做了一个类似教程 ...

  10. sqlserver数据库导入Mysql数据库问题

    近来遇到一个问题,之前的项目用的是SQLServer数据库,但是现在要换成MySQL数据库,所有整理了一些数据导入的步骤,供需要的人参考! 第一步: 第二步: 第三步: 第四步: 第五步: 第六步: ...