zoukankan      html  css  js  c++  java
  • C#的银行家算法的实现

    给个赞是对我最好的肯定~
      1 using System;
      2 
      3 namespace 银行家算法
      4 {
      5     class MainClass
      6     {
      7         public class Banker {  
      8             static int[] available = new int[4];       //资源数  
      9             static int[,] max = new int[5,4];          //最大资源需求
     10             static int[,] allocation = new int[5,4];   //已经分配的资源
     11             static int[,] need = new int[5,4];         //还需要的资源
     12             static int[] request = new int[4];         //存放请求
     13               
     14             int thread;  //线程号  
     15 
     16             //初始化各类的值  
     17             public void getData(){  
     18                 Console.Write("请输入A,B,C,D四类资源的数目:");  
     19                 //输入A,B,C三类资源数量  
     20                 for(int i = 0; i < 4; i++){  
     21                     available [i] = int.Parse (Console.ReadLine ());  
     22                 }  
     23                 //输入进程对三类资源的最大需求  
     24                 for(int i = 0; i < 5; i++){  
     25                     Console.WriteLine("请输入进程" + i + "对A,B,C,D三类资源的最大需求");  
     26                     for(int j = 0; j < 4; j++){  
     27                         max [i,j] = int.Parse (Console.ReadLine ()); 
     28                     }  
     29                 }  
     30                 //输入进程分配的三类资源数  
     31                 for(int i = 0; i < 5; i++){  
     32                     Console.WriteLine("请输入进程" + i + "已分配的A,B,C,D三类资源数");  
     33                     for(int j = 0; j < 4; j++){  
     34                         allocation[i,j] = int.Parse (Console.ReadLine ());  
     35                     }  
     36                 }  
     37                 //计算进程还需要的三类资源数  
     38                 for(int i = 0; i < 5; i++){  
     39                     for(int j = 0; j < 4; j++){
     40                         need[i,j] = max[i,j] - allocation[i,j];  
     41                     }  
     42                 }  
     43                 //重新计算available  
     44                 for(int i = 0; i < 4; i++){  
     45                     for(int j = 0; j < 5; j++){  
     46                         available[i] -= allocation[j,i];  
     47                     }  
     48                 }  
     49             }
     50 
     51             //用户输入要申请资源的线程和申请的资源,并进行判断  
     52             public void getThread(){  
     53                 Console.WriteLine("请输入申请资源的线程");  
     54                 int thread = int.Parse(Console.ReadLine());     //线程  
     55                 if(thread < 0 || thread > 4){  
     56                     Console.WriteLine("该线程不存在,请重新输入");  
     57                     getThread();
     58                 }else{  
     59                     this.thread = thread;  
     60                     Console.WriteLine("请输入申请的资源(0-4)");  
     61                     for(int i = 0; i < 4; i++){  
     62                         request[i] = int.Parse(Console.ReadLine());  
     63                     }  
     64                     if(request[0] > need[thread,0] || request[1] > need[thread,1] || request[2] > need[thread,2] || request[3] > need[thread,3]){  
     65                         Console.WriteLine(thread+"线程申请的资源超出其需要的资源,请重新输入");  
     66                         getThread();  
     67                     }else{  
     68                         if(request[0] > available[0] || request[1] > available[1] || request[2] > available[2] || request[3] > available[3]){
     69                             Console.WriteLine(thread + "线程申请的资源大于系统资源,请重新输入");  
     70                             getThread();  
     71                         }  
     72                     }  
     73                     changeData(thread);  
     74                     if(check(thread)){  
     75                         getThread();  
     76                     }else{  
     77                         recoverData(thread);  
     78                         getThread();  
     79                     }  
     80 
     81                 }  
     82             }  
     83 
     84             //thread线程请求响应后,试探性分配资源  
     85             public void changeData(int thread){  
     86                 for(int i = 0; i < 4; i++){  
     87                     //重新调整系统资源数  
     88                     available[i] -= request[i];  
     89                     //计算各个线程拥有资源  
     90                     allocation[thread,i] += request[i];  
     91                     //重新计算需求  
     92                     need[thread,i] -= request[i];  
     93                 }         
     94             }
     95 
     96             //安全性检查为通过,分配失败时调用,恢复系统原状           
     97             public void recoverData(int thread){  
     98                 for(int i = 0; i < 4; i++){  
     99                     //重新调整系统资源数  
    100                     available[i] += request[i];  
    101                     //计算各个线程拥有资源  
    102                     allocation[thread,i] -= request[i];  
    103                     //重新计算需求  
    104                     need[thread,i] += request[i];  
    105                 }   
    106             }  
    107 
    108             //对线程thread安全性检查  
    109             public bool check(int thread){  
    110                 bool[] finish = new bool[5];  
    111                 int[] work = new int[4];  
    112                 int[] queue = new int[5];   //由于存放安全队列  
    113                 int k = 0;//安全队列下标  
    114                 int j;  //要判断的线程  
    115                 int i;  
    116                 //是否分配的标志  
    117                 for( i = 0; i < 5; i++)  
    118                     finish[i] = false;  
    119                 j = thread;  
    120                 for(i = 0; i < 4; i++){  
    121                     work[i] = available[i];  
    122                 }  
    123                 while(j < 5){  
    124                     for( i = 0; i < 4; i++){    
    125                         if(finish[j]){  
    126                             j++;  
    127                             break;  
    128                         }else if(need[j,i] > work[i]){  
    129                             //(need[j,i]+"*"+i+work[i]);  
    130                             j++;  
    131                             break;  
    132                         }else if(i == 2){  
    133                             for(int m = 0; m < 4; m++){  
    134                                 work[m] += allocation[j,m];  
    135                             }  
    136                             finish[j] = true;  
    137                             queue[k] = j;  
    138                             k++;  
    139                             j = 0;   //从最小线程再开始判断  
    140                         }  
    141                     }  
    142                 }  
    143                 //判断是否都属于安全状态  
    144                 for(int p = 0; p < 5; p++){  
    145                     if(finish[p] == false){  
    146                         Console.WriteLine("系统不安全,资源申请失败");  
    147                         return false;  
    148                     }  
    149                 }  
    150                 Console.WriteLine("资源申请成功,安全队列为:");  
    151                 for(int q = 0; q < 5; q++){  
    152                     Console.WriteLine (queue [q]); 
    153                 }   
    154                 return true;  
    155             }
    156 
    157             //输出need和available
    158             public void showData(){
    159                 Console.WriteLine("need");
    160                 for(int i = 0; i < 5; i++){  
    161                     for(int j = 0; j < 4; j++){  
    162                         Console.WriteLine (need [i, j] + "     ");
    163                     }  
    164                 }  
    165                 Console.WriteLine("available");  
    166                 for(int j = 0; j < 4; j++){  
    167                     Console.WriteLine(available[j] + "     ");  
    168                 }  
    169             }
    170 
    171             static void Main(string[] args) {  
    172                 Banker bk = new Banker();  
    173                 bk.getData();  
    174                 bk.getThread();
    175             }
    176 
    177         }
    178 
    179     }
    180 }
  • 相关阅读:
    洛谷P2878 [USACO07JAN]保护花朵Protecting the Flowers
    洛谷P2434 [SDOI2005]区间
    洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn
    洛谷 P2904 [USACO08MAR]跨河River Crossing
    Again Stone Game
    Crazy Calendar (阶梯博弈变形)
    (2017浙江省赛E)Seven Segment Display
    ZOJ 3705 Applications
    D
    The Suspects(并查集维护根节点信息)
  • 原文地址:https://www.cnblogs.com/AlinaL/p/12852188.html
Copyright © 2011-2022 走看看