银行家算法(文件读入输出)

#include <iostream>  

#include<cstring>

#include<stdio.h>

using namespace std;  

#define MAXPROCESS 50                        /*最大进程数*/  

#define MAXRESOURCE 100                        /*最大资源数*/  

int AVAILABLE[MAXRESOURCE];                    /*可用资源数组*/  

int MAX[MAXPROCESS][MAXRESOURCE];            /*最大需求矩阵*/  

int ALLOCATION[MAXPROCESS][MAXRESOURCE];    /*分配矩阵*/  

int NEED[MAXPROCESS][MAXRESOURCE];            /*需求矩阵*/  

int REQUEST[MAXPROCESS][MAXRESOURCE];        /*进程需要资源数*/  

bool FINISH[MAXPROCESS];                        /*系统是否有足够的资源分配*/  

int p[MAXPROCESS];    

int flag[MAXPROCESS];                   /*记录序列*/  

int m,n;                                    /*m个进程,n个资源*/  

void Init();  

bool Safe();  

void Bank();  

void showdata(int,int);  

int main()  

{  

/*FILE *in = freopen(“in.txt”,”r”,stdin);

FILE *out = freopen(“out.txt”,”w”,stdout);*/

    Init();  

    Safe();  

    Bank();  

  /*  fclose(in);

    fclose(out);*/

}  

void Init()                /*初始化算法*/  

{  

    int i,j;  

    

    cin>>m;  

     

    cin>>n;  

   

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

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

            cin>>MAX[i][j];  

   

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

    {  

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

        {  

            cin>>ALLOCATION[i][j];  

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

            if(NEED[i][j]<0)  

            {  

                cout<<“您输入的第”<<i+1<<“个进程所拥有的第”<<j+1<<“个资源数 错误,请重新输入:”<<endl;  

                j–;  

                continue;  

            }  

        }  

    }  

    

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

    {  

        cin>>AVAILABLE[i];  

    }  

}  

void Bank()                /*银行家算法*/  

{  

    int i,cusneed,flag = 0;  

    char again;  

    while(cin>>cusneed)  

    {  

        showdata(n,m);

        cout<<endl;  

        if (cusneed > m)  

        {  

            cout<<“没有该进程,请重新输入”<<endl;  

        

        }  

        cout<<“请输入进程所请求的各资源的数量”<<endl;  

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

        {  

            cin>>REQUEST[cusneed][i];  

        }  

        int q = 0;

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

        {  

            if(REQUEST[cusneed][i]>NEED[cusneed][i])//如果用户选择的线程的第i个资源请求数>该线程该资源所需的数量  

            {  

                cout<<“不与分配”<<endl;  

                //goto input; 

                q = 1;

break; 

            }  

            if(REQUEST[cusneed][i]>AVAILABLE[i])//如果用户选择的线程的第i个资源请求数>系统现有的第i个资源的数量  

            {  

                cout<<“等待”<<endl;  

                //goto input;

                q = 1;

break; 

            }  

        }  

        if(q)

        continue;

        for(i=0;i<n;i++)//如果请求合理,那么下面  

        {  

            AVAILABLE[i]-=REQUEST[cusneed][i];//系统可用资源减去申请了的  

            ALLOCATION[cusneed][i]+=REQUEST[cusneed][i];//线程被分配的资源加上已申请了的  

            NEED[cusneed][i]-=REQUEST[cusneed][i];//线程还需要的资源减去已申请得到的  

        }  

        if(Safe())//AVAILABLE  ALLOCATION  NEED变动之后,是否会导致不安全  

        {  

            cout<<“同意分配请求!”<<endl;  

        }  

        else  

        {  

            cout<<“您的请求被拒绝!”<<endl;  

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

            {  

                AVAILABLE[i]+=REQUEST[cusneed][i];  

                ALLOCATION[cusneed][i]-=REQUEST[cusneed][i];  

                NEED[cusneed][i]+=REQUEST[cusneed][i];  

            }  

        }  

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

        {  

            if (NEED[cusneed][i] <= 0)  

            {  

                flag++;  

            }  

        }  

        if (flag == n)//如果该进程各资源都已满足条件,则释放资源  

        {  

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

            {  

                AVAILABLE[i] += ALLOCATION[cusneed][i];  

                ALLOCATION[cusneed][i] = 0;  

                NEED[cusneed][i] = 0;  

            }  

            cout<<“线程”<<cusneed<<” 占有的资源被释放!”<<endl;  

            flag = 0;  

        }  

        for(i=0;i<m;i++)//分配好了以后将进程的标识FINISH改成false  

        {  

            FINISH[i]=false;  

        }  

        /*cout<<“您还想再次请求分配吗?是请按y/Y,否请按其它键”<<endl;  

        cin>>again;  

        if(again==’y’||again==’Y’)  

        {  

            continue;  

        } 

break;  */

        

    }  

}  

bool Safe()                                    /*安全性算法*/  

{  

    int i,j,k,l=0;  

    int Work[MAXRESOURCE];                    /*工作数组*/  

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

        Work[i]=AVAILABLE[i];  

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

    {  

        FINISH[i]=false;//FINISH记录每个进程是否安全  

    } 

memset(flag,0,sizeof(flag)); 

    for(i=0;;i++)  

    {     

   
if(i>=2*m)

   
break;

   
int tmp = i%m;

   
for(j=0;!flag[tmp]&&j<n;j++)//循环查找第i个进程需要的各个资源数 是否 超过系统现有的对应的资源数  

        {  

            if(NEED[tmp][j]>Work[j])//第i个进程需要的第j个资源数 > 系统现有的第j个资源数  

            {  

                break;  

            }  

        }  

        if(j==n)//如果第i个进程所需的各个资源数都没有超过系统现有的对应资源数  

        {   

            FINISH[tmp]=true;//给该进程的FINISH标记为true  

            for(k=0;k<n;k++)  

            {  

                Work[k]+=ALLOCATION[tmp][k];//将Work赋值为 第i个进程各个已分配资源数+系统现有的对应资源数(因为当改进程全部资源数都满足时线程结束并将资源返还给系统)  

            }  

            p[l++]=tmp;//记录进程号 

flag[tmp] = 1; 

        }  

        else//如果超过继续循环下一个进程  

        {  

            continue;   

        }  

        if(l==m)//当所有程都能够被满进足运行时  

        {  

            cout<<“系统是安全的”<<endl;  

            cout<<“安全序列:”<<endl;  

            for(i=0;i<l;i++)//  

            {  

                cout<<p[i];  

                if(i!=l-1)  

                {  

                    cout<<“–>”;  

                }  

            }  

            cout<<“”<<endl;           

            return true;  

        }  

    }//for循环  

    cout<<“系统是不安全的”<<endl;  

    return false;  

}  

  

void showdata(int n,int m)   //显示  

{  

    int i,j;  

    cout<<endl;    

    cout<<“————————————————————-“<<endl;    

    cout<<“系统可用的资源数为:    “;  

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

        cout<<”    “<<AVAILABLE[j];        

    cout<<endl;     

    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<<endl;     

  

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

    {  

        cout<<”    进程”<<i<<“:”;     

  

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

            cout<<”     “<<ALLOCATION[i][j];  

        cout<<endl;     

    }    

    cout<<endl;   

}   

    原文作者:银行家问题
    原文地址: https://blog.csdn.net/lison_zhu/article/details/72286398
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞