SJF

#include<stdio.h>

#define    MAX   100

typedef struct PCB
{
    char    ProName[10];     //作业ID
    float   ArriveTime;       //到达时刻
    float   Fun_time;       //运行时间
    float   EndTime;       //完成时间
    float   revolveTime;       //周转时间
    int     Order;          //优先标记
} list,*linklist;

void sjf(linklist p,int count)
{
    list item;            //结构体变量
    int i = 0;
    int j = 0;
    int k = 0;           //最短运行时间作业的下标
    int flag = 0;        //优先级设置
    float min = 0;       //最短运行时间
    float temp;          //开始的时刻

    temp = p[0].ArriveTime;//开始的时刻为第一个到达的时间

    //先求出最先到达作业的时刻
    for(i = 0; i < count; i++)
    {
        if(temp > p[i].ArriveTime)
        {
            temp = p[i].ArriveTime;        //保存最先到达的作业的时刻
            k = i;                                          //最先到达的作业的下标,默认为p[0]
        }
    }


    for(i = 0; i < count; i++)
    {
        p[k].Order = ++flag;                             //设置优先级为1,最高优先级
        p[k].EndTime   = temp + p[k].Fun_time;
        p[k].revolveTime   = p[k].EndTime - p[k].ArriveTime;

        min = 100;

        temp = p[k].EndTime;                  //后一个作业的开始时刻是前一个作业的完成时刻

        for(j = 0; j < count; j++)
        {
            if(p[j].Order != 0 || temp - p[j].ArriveTime <= 0)  //跳过不满足条件的(已设置优先级的 和 到达时刻要晚于前一个作业的完成时刻的)
                continue;
            if(min > p[j].Fun_time)
            {
                min = p[j].Fun_time;
                k = j;          //求出满足条件最短运行时间的作业的下标
            }
        }
    }

    for(i = 1; i < count; i++)     //按优先级排序
    {
        item = p[i];
        j = i-1;

        while(item.Order < p[j].Order && j >= 0)
        {
            p[j+1] = p[j];      //order越小优先级越高,小的往前移
            --j;
        }
        p[j+1] = item;
    }

    return;
}

//输出各个作业的详细信息
void print(linklist p,int count)
{
    int i;
    printf("ID\t到达\t服务\t完成\t周转\n");

    for(i = 0; i < count; i++)
    {
        printf("%s\t%.0f\t%.0f\t%.0f\t%.0f\n",
               p[i].ProName,p[i].ArriveTime,p[i].Fun_time, p[i].EndTime,p[i].revolveTime);

    }


    return;
}


int main()
{
    list st[MAX];                  //最多可以一百个作业
    int num = 0;                 //作业数量

    int i = 0;

    printf("请输入作业数量:");
    scanf("%d",&num);

    printf("请输入作业ID,到达时间,运行时间:\n");

    for(i=0; i<num; i++)
    {
        scanf("%s %f %f",st[i].ProName,&st[i].ArriveTime,&st[i].Fun_time);
        st[i].Order = 0;     //优先级初始化
    }

    sjf(st,num);
    print(st,num);
    return 0;
}

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值