试验二

#include<stdio.h>
#include<string.h>
#define N 100
struct JCB{
    char name[10];
    int atime;
    int stime;
    int ftime;
    float ztime;
    float dcztime;
    };
    JCB a[N];
    void FCFS(int number,JCB a[N]);

void main()
{
    int number,i;
    
    printf("please input the number of the job: ");
    scanf("%d",&number);
    for(i=0;i<number;i++)
    {
        printf("name:");
        scanf("%s",&a[i].name);
        printf("atime:");
        scanf("%d",&a[i].atime);
        printf("stime:");
        scanf("%d",&a[i].stime);
    }
    
    FCFS(number,a);
}





void FCFS(int number, JCB a[N])
{
    int i,j,l,y;
    char k[N];
    for(i=0;i<number;i++) //按进程到达时间的先后排序
 {                               //如果两个进程同时到达,按在屏幕先输入的先运行
  for(j=i+1;j<number;j++)
  { 
   if(a[j].atime<a[i].atime)
   {
    l=a[j].atime;
    a[j].atime=a[i].atime;
    a[i].atime=l;
    y=a[j].stime;
    a[j].stime=a[i].stime;
    a[i].stime=y;
    strcpy(k,a[j].name);
    strcpy(a[j].name,a[i].name);
    strcpy(a[i].name,k);
   }
  }
 }
for(i=0;i<number;i++)
{
    a[i].ftime=a[i].atime+a[i].stime;
    a[i].ztime=a[i].ftime-a[i].atime;
}
 for(i=0;i<number;i++)
 {
     // a[i].ftime=a[i].atime+a[i].runtime;
      printf("%5s%5d%5d\n",a[i].name,a[i].atime,a[i].stime);
    //  a[i+1].atime=a[i].ftime;
 }

}

做了,先来先服务的排序,还没完成先来先服务,不太会做。

posted on 2015-05-03 22:21  03李嘉晖  阅读(111)  评论(0编辑  收藏  举报

导航