-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFCFS.c
73 lines (73 loc) · 1.31 KB
/
FCFS.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include <stdio.h>
#include <malloc.h>
#include <math.h>
struct process
{
int at,bt,ft,wt,pid,tat;
};
typedef struct process p_adt;
void dis(p_adt *p,int no,float avg,float tat)
{
int i;
printf("\n\t\t********FCFS*********\n");
printf("\nP_ID Arrival\t\tBurst\t\tTurnAround\t\tWait\n");
for(i=0;i<no;i++)
{
printf("%d\t %d\t\t %d\t\t %d\t\t %d\n",p[i].pid,p[i].at,p[i].bt,p[i].tat,p[i].wt);
}
printf("Average Waiting Time is :%f\n",avg);
printf("Average Turn Around time is:%f\n",tat);
}
float turnAround(p_adt*p,int n)
{
int i;
float tave=0;
for(i=0;i<n;i++)
{
p[i].tat=p[i].ft-p[i].at;
tave+=p[i].tat;
}
return tave/n;
}
void finish(p_adt *p,int n)
{
int current=0,i;
for(i=0;i<n;i++)
{
current+=p[i].bt;
p[i].ft=current;
}
}
float average(p_adt *p,int n)
{
int i;
float ave=0;
for(i=0;i<n;i++)
{
p[i].wt=p[i].ft-(p[i].bt+p[i].at);
ave+=p[i].wt;
}
return ave/n;
}
void main()
{
int n,i;
printf("enter the size of array\n");
scanf("%d",&n);
p_adt *p=(p_adt*)malloc(n*sizeof(p_adt));
for(i=0;i<n;i++)
{
printf("Enter the arrival time of process %d-> ",i);
p[i].pid=i;
scanf("%d",&p[i].at);
}
for(i=0;i<n;i++)
{
printf("Enter the burst time of process %d-> ",i);
scanf("%d",&p[i].bt);
}
finish(p,n);
float avg=average(p,n);
float tat=turnAround(p,n);
dis(p,n,avg,tat);
}