-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathpreemptive priority scheduling.cpp
108 lines (95 loc) · 2.04 KB
/
preemptive priority scheduling.cpp
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#include<stdio.h>
#include<stdlib.h>
# define MAX_VALUE 9999;
void sort(int* a, int *b,int* pt,int *pro,int n){
int j,key1,key2,key3,key4;
for(int i=1; i<n; i++){
j=i-1;
key1=a[i];
key2=b[i];
key3=pt[i];
key4=pro[i];
while(j>=0 && key1<a[j]){
a[j+1]=a[j];
b[j+1]=b[j];
pro[j+1]=pro[j];
pt[j+1]=pt[j];
j--;
}
a[j+1]=key1;
b[j+1]=key2;
pt[j+1]=key3;
pro[j+1]=key4;
}
}
int findLeastPriority(int* priority, int* at, int ct,int n){
int min_value=priority[0];
int min_index=0;
for(int i=0; i<n && at[i]<=ct; i++){
if(priority[i]<min_value){
min_value=priority[i];
min_index=i;
}
}
return min_index;
}
int main(){
int n;
printf("Enter no of processes: ");
scanf("%d",&n);
int at[n],bt[n],bt1[n],pt[n],pt1[n],ct[n],tat[n],wt[n],pro[n];
printf("\npriority at bt\n");
for(int i=0; i<n; i++){
scanf("%d%d%d",&pt[i],&at[i],&bt[i]);
pro[i]=i+1;
}
sort(at,bt,pt,pro,n);
for(int i=0; i<n; i++)
{
bt1[i]=bt[i];
pt1[i]=pt[i];
}
// calculating complete time
printf("\nGantt Chart\n");
int prev_i,c,i,loop_count=n;
i=findLeastPriority(pt,at,at[0],n);
printf("p%d ",pro[i]);
c=at[i]+1;
ct[i]=c;
bt[i]--;
if(bt[i]==0)
{
pt[i]=MAX_VALUE;
loop_count--;
}
while(loop_count>0)
{
//printf("lc=%d\n",loop_count);
prev_i=i;
i=findLeastPriority(pt,at,c,n);
//printf("i=%d\n",i);
if(prev_i!=i)
printf("p%d ",pro[i]);
c++;
ct[i]=c;
bt[i]--;
if(bt[i]==0)
{
pt[i]=MAX_VALUE;
loop_count--;
}
}
// calculating waiting and turn around time
float sum_tat=0.0,sum_wt=0.0;
for(int i=0; i<n; i++){
tat[i]=ct[i]-at[i];
wt[i]=tat[i]-bt1[i];
sum_tat=sum_tat+tat[i];
sum_wt=sum_wt+wt[i];
}
printf("\n\npro pt at bt ct tat wt\n");
for(int i=0; i<n; i++){
printf("p%d\t%d\t%d\t%d\t%d\t%d\t%d\n",pro[i],pt1[i],at[i],bt1[i],ct[i],tat[i],wt[i]);
}
printf("\nAvg Turn Around Time: %.2f\nAvg Waiting Time: %.2f\n",sum_tat/n,sum_wt/n);
}