-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathround_robin.c
More file actions
61 lines (50 loc) · 1.51 KB
/
Copy pathround_robin.c
File metadata and controls
61 lines (50 loc) · 1.51 KB
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
#include<stdio.h>
int main()
{
int i, j, n, bu[10], wa[10], tat[10], t, ct[10], max;
float awt = 0, att = 0, temp = 0;
printf("Enter the no of processes -- ");
scanf("%d", &n);
for(i = 0; i < n; i++)
{
printf("\nEnter Burst Time for process %d -- ", i+1);
scanf("%d", &bu[i]);
ct[i] = bu[i];
}
printf("\nEnter the size of time slice -- ");
scanf("%d", &t);
// Find maximum burst time
max = bu[0];
for(i = 1; i < n; i++)
if(max < bu[i])
max = bu[i];
// Round Robin Scheduling
for(j = 0; j < (max/t) + 1; j++)
for(i = 0; i < n; i++)
if(bu[i] != 0)
if(bu[i] <= t)
{
tat[i] = temp + bu[i];
temp = temp + bu[i];
bu[i] = 0;
}
else
{
bu[i] = bu[i] - t;
temp = temp + t;
}
// Calculate waiting time and averages
for(i = 0; i < n; i++)
{
wa[i] = tat[i] - ct[i];
att += tat[i];
awt += wa[i];
}
// Print results
printf("\nThe Average Turnaround time is -- %f", att/n);
printf("\nThe Average Waiting time is -- %f", awt/n);
printf("\n\tPROCESS\t BURST TIME \t WAITING TIME\tTURNAROUND TIME\n");
for(i = 0; i < n; i++)
printf("\t%d \t %d \t\t %d \t\t %d \n", i+1, ct[i], wa[i], tat[i]);
return 0;
}