-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpriority.c
179 lines (151 loc) · 4.17 KB
/
priority.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
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
#include <stdio.h>
#include <stdlib.h>
typedef struct
{
int pid;
int bt;
int at;
int prio;
int ft;
int tat;
int wt;
} Process;
void sort(int n, Process p[n])
{
int i, j;
Process temp;
//ye sorting ka logic trass hai
//dono for ratt lo, maine sort kaise karna geeks se uthaya
for(i=0; i<n-1; i++)
for(j=0; j<(n-1-i); j++)
if((p[j].at > p[j + 1].at) || ((p[j].at == p[j+1].at) && (p[j].prio > p[j+1].prio)))
{
temp = p[j];
p[j] = p[j + 1];
p[j + 1] = temp;
}
}
int execute(int t, int n, Process p[n])
{
//fills in values for tat and wt for each process
int i;
for(i=0; i<n; i++)
{
if(i==0)
t = p[i].at;
t = t +p[i].bt;
p[i].ft = t;
p[i].tat = p[i].ft - p[i].at;
p[i].wt = p[i].tat - p[i].bt;
}
return t;
}
void print_table(int n,Process p[n])
{
int i, avgw = 0, avgt = 0;
printf("\n\n\tpid\tAt\tBt\tPrio\tFt\tTAt\tWt\n");
for(i=0;i<n;i++)
{
avgw = avgw + p[i].wt;
avgt = avgt + p[i].tat;
if(p[i].pid != -1)
printf("\n\t%d\t%d\t%d\t%d\t%d\t %d\t%d\n",p[i].pid,p[i].at,p[i].bt,p[i].prio,p[i].ft,p[i].tat,p[i].wt);
}
avgw = (avgw/n);
avgt = (avgt/n);
printf("\n\n\tAverage waiting time: %d units\n\tAverage turn-around time: %d units",avgw,avgt);
}
void print_chart(int n, Process p[n])
{
int i, j;
printf("\n\t+");
for(i=0; i<n; i++)
{ for(j=1; j<=p[i].bt; j++)
printf("---");
printf("+");
}
printf("\n\t|");
for(i=0; i<n; i++)
{
printf(" P%d",p[i].pid);
for(j=1; j<p[i].bt; j++)
printf(" ");
printf("|");
}
printf("\n\t+");
for(i=0; i<n; i++)
{ for(j=1; j<=p[i].bt; j++)
printf("---");
printf("+");
}
int check = 0;
printf("\n\t%d",p[0].at);
if(p[0].at > 9)
check = 1;
for(i=0; i<n; i++)
{ for(j=1; j<=p[i].bt; j++)
if(check == 1) //try commenting for here
{
printf(" ");
check = 0;
}
else
printf(" "); //to here and just keep printf(" ");
printf("%d",p[i].ft);
if(p[i].ft > 9)
check = 1;
}
}
int main()
{
int n, i, j ;
printf("\n\t\t\t\tPriority\n\n\t Enter the total number of processes: "); scanf("%d",&n);
Process p[n];
printf("\n\t Enter the following data for each process: ");
for(i=0; i<n; i++)
{
printf("\n\t Process %d:\n\tArrival time: ",i+1);
scanf("%d",&p[i].at);
printf("\tBurst time: ");
scanf("%d",&p[i].bt);
printf("\tPriority: ");
scanf("%d",&p[i].prio);
p[i].pid = i+1;
}
sort(n,p); //sorted on arrival and priority time
int t = 0;
t = execute(t,n,p); //calculating wt and tat for each process
//tat = ft - at
//wt = tat - bt
printf("\n\t %d \n",t);
print_table(n,p);
printf("\n\n\t Gnatt chart\n");
print_chart(n,p);
int s = t + 2;
int m;
printf("\n\n\n\t\t\tRandom CPU Burst\n\n\t Enter the total number of processes: "); scanf("%d",&m);
int upbt = 5, lowbt = 1, upprio = m, lowprio = 1, rand_prio, rand_at, rand_bt;
Process q[m];
for(i=0; i<m; i++)
{
rand_at = s;
s++;
rand_bt = (rand() % (upbt - lowbt + 1)) + lowbt;
rand_prio = (rand() % (upprio - lowprio + 1)) + lowprio;
q[i].at = rand_at;
q[i].bt = rand_bt;
q[i].prio = rand_prio;
q[i].pid = i+1;
}
sort(m,q);
t = execute(t,m,q);
print_table(m,q);
printf("\n\n\t Gnatt chart\n");
print_chart(m,q);
printf("\n\n");
printf("\n\n\t Combined Gnatt chart\n");
print_chart(n,p);
printf("\n\n\t\t--IO of 2 units--\n");
print_chart(m,q);
return 0;
}