操作系统实验:银行家算法C语言实现

操作系统实验:银行家算法C语言实现银行家算法C语言实现#include<stdio.h>#include<stdlib.h>#defineok1#definetrue1#definefalse0intclaim[100][100]={0};//各个进程需要的最大资源数量intalloc[100][100]={0};//各个进程已分配的资源数量intneed[100][100]={0};//各个进程还需要的资源数量intresource[100]={

大家好,又见面了,我是你们的朋友全栈君。

银行家算法C语言实现

#include<stdio.h>
#include<stdlib.h>
#define ok 1
#define true 1
#define error 0
#define false 0

int claim[100][100] = { 
   0}; // 各个进程需要的最大资源数量
int alloc[100][100] = { 
   0}; // 各个进程已分配的资源数量
int need[100][100] = { 
   0};  // 各个进程还需要的资源数量
int resource[100] = { 
   0};   // 各个资源的总数
char name[100] = { 
   0};      // 各个资源的名字
int available[100] = { 
   0};  // 可分配的资源数
int work[100] = { 
   0};       // 用于存放alloc+available两个数组和的值
int finish[100] = { 
   0};     // 判断是否分配完成
int ss[100] = { 
   0};         // 安全序列
int request[100] = { 
   0};    // 请求单独分配的资源数量
int n, m; // n:进程的数量 m:资源的种数

int init()
{ 
   
    int i, j;
    //char Name;

    printf("请输入进程所需资源的种数:");
    scanf("%d", &m);
    for(i = 0; i < m; i++)
    { 
   
        printf("请输入资源%d的名字:", i);
        fflush(stdin);// 用于刷新缓冲区,VScode这里一定要这么做
        scanf("%c", &name[i]);
        //name[i] = Name;
        printf("请输入资源%c的资源总数:", name[i]);
        scanf("%d", &resource[i]);
    }
    printf("==============================\n");
    printf("请输入各个资源可分配的资源数:\n");
    for(i = 0; i < m; i++)
    { 
   
        printf("%c:", name[i]);
        scanf("%d", &available[i]);
    }
    printf("==============================\n");
    printf("请输入进程的数量:");
    scanf("%d", &n);
    printf("请输入各个进程需要的最大资源数量:\n");
    for(i = 0; i < n; i++)
    { 
   
        for(j = 0; j < m; j++)
            scanf("%d", &claim[i][j]);
    }
    printf("==============================\n");
    printf("请输入各个进程已分配的资源数量:\n");
    for(i = 0; i < n; i++)
    { 
   
        for(j = 0; j < m; j++)
            scanf("%d", &alloc[i][j]);
    }
    return ok;
}

int safe()
{ 
   
    int i, j, k, s = 0;
    int flag;
    int t;

    //初始化work数组,在available数组改变时用于替换available数组进行加法的运算。
    for(j = 0; j < m; j++)
        work[j] = available[j];
    //初始化finish数组,用于在分配完之后跳过这个进程。
    for(i = 0; i < n; i++)
        finish[i] = false;
    //算出各个进程还需要的各种资源的数量。
    for(i = 0; i < n; i++)
    { 
   
        for(j = 0; j < m; j++)
        { 
   
            need[i][j] = claim[i][j] - alloc[i][j];
        }
    }
    printf("==============================\n");
    printf("各个进程还需要的资源数量:\n");
    for(i = 0; i < n; i++)
        printf("%c ", name[i]);
        printf("\n");
    for(i = 0; i < n; i++)
    { 
   
        for(j = 0; j < m; j++)
        { 
   
            printf("%d ", need[i][j]);
        }
        printf("\n");
    }
    printf("==============================\n");
    printf("判断是否安全:");
    for(i = 0; i < n; i++)
    { 
   
        t = 0;
        for(j = 0; j < m; j++)
        { 
   
            if(work[j] >= need[i][j] && finish[i] == false)
            { 
   
                t++;
                if(t == m)
                { 
   
                    for(k = 0; k < m; k++)
                    work[k] = work[k] + alloc[i][k];
                    finish[i] = true;
                    ss[s++] = i;
                    i = -1;//保证每次都从第一行开始找起
                }
            }    
        }
    }
    for(i = 0; i < n; i++)
    { 
   
        if(finish[i] == false)
        { 
      
            printf("不安全!");
            return error;
        }
    }
    printf("安全,存在一个安全序列:");
    for(i = 0; i < n; i++)
    { 
   
        printf("P%d", ss[i]);
        if(i < n-1)
         printf("->");
    }
    printf("\n");
    return ok;
}

int  banker()
{ 
   
    int p, i, j;
    int flag = true;

    printf("==============================\n");
    printf("请输入第几个进程请求分配的资源(0~%d):", n-1);
    scanf("%d", &p);
    printf("请分别输入请求分配的资源数量:\n");
    for(i = 0; i < m; i++)
    { 
   
        printf("%c:", name[i]);
        scanf("%d", &request[i]);
    }

    for(j = 0; j < m; j++)
    { 
   
        if((request[j] + alloc[p][j]) > claim[p][j])
        { 
   
            printf("不合理\n");
            flag = false;
            break;
        }
        else
        { 
   
            if(request[j] > available[j])
            { 
   
                printf("不可能\n");
                flag = false;
                break;
            }
        }
    }

    if(flag)
    { 
   
        test(p);  // 尝试将请求的资源数量分配到请求的进程
        safe();
        reset(p); // 重置可分配的数组和已分配的数组
    }
    return ok;
}

int test(int i)
{ 
   
    int j;
    for(j = 0; j < m; j++)
    { 
   
        available[j] = available[j] - request[j];
        alloc[i][j] = alloc[i][j] + request[j];
    }
}

int reset(int i)
{ 
   
    int j;
    for(j = 0; j < m; j++)
    { 
   
        available[j] = available[j] + request[j];
        alloc[i][j] = alloc[i][j] - request[j];
    }
}

int main()
{ 
   
    int t = 0;

    while(t != 4){ 
   
    printf("------------------------------\n");
    printf(" 银行家算法模拟 \n");
    printf("------------------------------\n");
    printf("1: 初始化 2:判断是否安全\n");
    printf("3:请求分配 4:退出 \n");
    printf ("请选择(1~4):");
    scanf("%d", &t);
    switch(t)
        { 
   
            case 1 :
                    init();
                break;
            case 2:
                    safe();
                break;
            case 3:
                    banker();
                break;
            case 4 :
                    printf("银行家算法模拟结束Bye!");
                exit(0);
        }
    }
    return 0;
} 

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137843.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java mysql 分页_mysql分页查询总结

    java mysql 分页_mysql分页查询总结mysql分页查询总结mysql提供分页的功能:SELECT*FROMtableLIMIT[offset,]rows|rowsOFFSEToffsetLIMIT子句可以被用于强制SELECT语句返回指定的记录数。LIMIT接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行…

    2022年6月24日
    31
  • css3 画半圆和1/4圆

    css3 画半圆和1/4圆

    2021年9月13日
    65
  • (更新)2009.5.23 软考 网络管理员 上午试题 答案 讨论

    (更新)2009.5.23 软考 网络管理员 上午试题 答案 讨论

    2021年7月30日
    64
  • 数据结构中的elem,elemtype是什么

    数据结构中的elem,elemtype是什么elem是单词element(元素)的缩写,在程序定义中代表某一不确定的类型,也就是抽象的数据类型。为了使程序可读性强,并且便于修改,让elem代表多种的数据类型,也就是为int、char等等的数据类型,起了一个别名。ElemType是数据结构的书上为了说明问题而用的一个词。它是elementtype(“元素的类型”)的简化体。 因为数据结构是讨论抽象的数据结构和算法的,一种结构中元素的类型…

    2022年5月12日
    83
  • Math.abs( x )

    Math.abs( x )

    2021年10月18日
    67
  • Unity 3D游戏开发学习教程

    Unity 3D游戏开发学习教程用C#用Unity3D制作游戏你会学到:您将学习3D游戏开发基础知识,以使用Unity3D引擎推进事物。到本课程结束时,他们将可以轻松制作任何类型的游戏,无论是3D还是2DMP4|视频:h264,1280×720|音频:AAC,44.1KHz,2Ch语言:英语+中英文字幕(根据原英文字幕机译更准确)|时长:87节课(11h32m)|大小解压后:5.86GB描述用Unity3D开发3D游戏《2021年》是一门结构完善的高级UnityC#课程,专为完全…

    2022年9月15日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号