zoukankan      html  css  js  c++  java
  • 银行家算法——C语言(11计科1班-孙鹏启——修正)

    #define M 50
    #include "stdio.h"
    int max[M][M], allocation[M][M], need[M][M], available[M];    /*定义全局变量 */
    int i, j, n, m, r, t;
    void main()
    {
        void check();
        void print();
        int p, q;
        int req[M], allocation1[M][M], need1[M][M], available1[M];
        printf("Please input the  processes sum:");
        scanf("%d", &n);    /*输入进程总数 */
        printf("Please input the  kinds  sum :");
        scanf("%d", &m);    /*输入资源种类总数 */
        printf("please input the max resources :");
        for (i = 0; i < n; i++)
            for (j = 0; j < m; j++) {
                scanf("%2d", &max[i][j]);
            }        /*输入最大矩阵 */
        printf("please input the allocation resources :");
        for (i = 0; i < n; i++)
            for (j = 0; j < m; j++)
                scanf("%d", &allocation[i][j]);    /*输入已分配资源数 */
        printf("please input the need resources :");
        for (i = 0; i < n; i++)
            for (j = 0; j < m; j++) {
                need[i][j] = max[i][j] - allocation[i][j];
                printf("%2d", need[i][j]);
            }        /*输出还需要的资源数 */
        printf(" please input the available number :");
        for (i = 0; i < m; i++)
            scanf("%d", &available[i]);    /*输入可用资源数 */

        check();        /*检测已知的状态是否安全 */
        if (r == 1) {        /*如果已知的状态安全则执行以下代码 */
            do {
                t = 1;
                p = 0, q = 0;
                printf(" please input the NO. of process: ");
                scanf("%d", &i);    /*输入请求资源的进程号 */
                printf("please input the resources of request:");
                for (j = 0; j < m; j++)
                    scanf("%d", &req[j]);    /*输入该进程所需的资源数 */

                for (j = 0; j < m; j++)
                    if (req[j] > need[i][j])
                        p = 1;    /*判断请求是否超过最大资源数 */
                if (p)
                    printf("The resources of request have been beyond the max number needed!");
                else {
                    for (j = 0; j < m; j++)
                        if (req[j] > available[j])
                            q = 1;    /*判断请求是否超过可用资源数 */
                    if (q)
                        printf("There are not enough available resources!");
                    else {
                        for (j = 0; j < m; j++) {    /*请求满足条件 */
                            available1[j] = available[j];    /* 保存原已分配的资源数,需要的资源数,和可用的资源数 */
                            allocation1[i][j] = allocation[i][j];
                            need1[i][j] = need[i][j];

                            available[j] = available[j] - req[j];    /* 系统尝试把资源分配给请求的进程 */
                            allocation[i][j] = allocation[i][j] + req[j];
                            need[i][j] = need[i][j] - req[j];
                        }
                        print();    /*输出可用资源数 */
                        check();    /*进行安全检测 */
                        if (r == 0) {    /*分配后状态不安全 */
                            for (j = 0; j < m; j++) {
                                available[j] = available1[j];    /* 还原分配前的已分配的资 源数,仍需要的资源数和可用的资源数 */
                                allocation[i][j] = allocation1[i][j];
                                need[i][j] = need1[i][j];
                            }
                            printf(" This is unsafe  and  return: ");
                            print();
                        }
                    }
                }

                printf(" Do you want to continue? y(1) or n(0):");    /*判断是否继续进行资源分配 */
                scanf("%d", &t);
            } while (t == 1);
        }
    }

    void check()
    {                /*检测函数 */
        int k, f, v = 0;
        int work[M], a[M];
        char finish[M];
        r = 1;
        for (i = 0; i < n; i++)
            finish[i] = 'F';    /*初始化各进程均没得到足够资源并完成 */
        for (j = 0; j < m; j++)
            work[j] = available[j];    /*用work[j]表示可提供进程继续运行的各类资源数 */
        k = n;
        do {
            for (i = 0; i < n; i++) {
                if (finish[i] == 'F') {
                    f = 1;
                    for (j = 0; j < m; j++)
                        if (need[i][j] > work[j])
                            f = 0;
                    if (f == 1) {    /*找到还没完成的且需求数小于可提供进程继续运行的 */
                        finish[i] = 'T';    /*资源数的进程 */
                        a[v++] = i;    /*记录安全序列 */
                        for (j = 0; j < m; j++)
                            work[j] = work[j] + allocation[i][j];    /*释放该进程已分配的资源 */

                    }
                }
            }
            k--;
        } while (k > 0);
        f = 1;
        for (i = 0; i < n; i++) {    /*判断是否所有的进程都完成 */
            if (finish[i] == 'F') {
                f = 0;
                break;
            }
        }
        if (f == 0) {        /*若有进程没完成,则为不安全状态 */
            printf("This is unsafe . ");
            r = 0;
        } else {        /* 否则为安全状态 */

            printf("This is safe .");
            printf(" the safe number is:");
            for (i = 0; i < n; i++)
                printf("%d ", a[i]);    /*输出安全序列 */

            printf(" ");
            for (i = 0; i < n; i++) {
                printf("%2d", i);
                printf("     ");
                for (j = 0; j < m; j++)
                    printf("%2d", allocation[i][j]);
                printf("     ");
                for (j = 0; j < m; j++)
                    printf("%2d", need[i][j]);
                printf(" ");
            }

        }
    }

    void print()
    {                /*输出函数 */
        int process[M];
        printf("The available  resources: ");
        for (j = 0; j < m; j++)
            printf("%2d ", available[j]);
        printf(" ");
    }



    ++++++++++++++++++++++++++++++++++++++++++++++++

    [root@localhost 银行家]# gcc banker.c -o banker
    [root@localhost 银行家]# ./banker
    Please input the  processes sum:5
    Please input the  kinds  sum :3
    please input the max resources :7 5 3 3 2 2 9 0 2 2 2 2 4 3 3
    please input the allocation resources :0 1 0 2 0 0 3 0 2 2 1 1 0 0 2
    please input the need resources : 7 4 3 1 2 2 6 0 0 0 1 1 4 3 1
    please input the available number :3 3 2
    This is safe . the safe number is:1 3 4 0 2
     0      0 1 0      7 4 3
     1      2 0 0      1 2 2
     2      3 0 2      6 0 0
     3      2 1 1      0 1 1
     4      0 0 2      4 3 1

    please input the NO. of process: 1
    please input the resources of request:1 0 2
    The available  resources:
     2  3  0
    This is safe . the safe number is:1 3 4 0 2
     0      0 1 0      7 4 3
     1      3 0 2      0 2 0
     2      3 0 2      6 0 0
     3      2 1 1      0 1 1
     4      0 0 2      4 3 1

    Do you want to continue? y(1) or n(0):1

    please input the NO. of process: 4
    please input the resources of request:3 3 0
    There are not enough available resources!
    Do you want to continue? y(1) or n(0):1

    please input the NO. of process: 0
    please input the resources of request:0 2 0
    The available  resources:
     2  1  0
    This is unsafe .
     This is unsafe  and  return:
    The available  resources:
     2  3  0

    Do you want to continue? y(1) or n(0):0
    [root@localhost 银行家]#

    <script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>
    阅读(1163) | 评论(0) | 转发(11) |
    给主人留下些什么吧!~~
    评论热议
  • 相关阅读:
    linux文件系统初探--Day6
    Oracle 内置函数
    libusb常用函数说明(转)
    将多个blv格式的视频合并为一个mp4格式视频
    泰迪杯赛后总结
    如何下载B站上版权受限的视频?
    查看Ubuntu版本信息
    Visual Studio存在多个项目时启动项目的问题
    mfc | 初识mfc
    re | [ACTF新生赛2020]Splendid_MineCraft
  • 原文地址:https://www.cnblogs.com/ztguang/p/12648225.html
Copyright © 2011-2022 走看看