Operating System46761
Operating System46761
FCFS
#include<stdio.h>
int main()
int n,bt[20],wt[20],tat[20],avwt=0,avtat=0,i,j;
scanf("%d",&n);
for(i=0;i<n;i++)
printf("p[%d]",i+1);
scanf("%d",&bt[i]);
wt[0]=0;
for (i=1;i<n;i++)
wt[i]=0;
for(j=0;j<n;j++)
wt[i]+=bt[j];
for(i=0;i<n;i++)
tat[i]=bt[i]+wt[i];
avwt+=wt[i];
22701F00I5 Page 1
OS
avtat+=tat[i];
printf("\np[%d]\t\t%d\t\t%d\t\t%d",i+1,bt[i],wt[i],tat[i]);
avwt/=i;
avtat/=i;
return 0 ;
22701F00I5 Page 2
OS
main()
int p[20],bt[20],wt[20],tat[20],i,k,n,temp;
float wtavg,tatavg;
scanf("%d",&n);
for(i=0;i<n;i++)
p[i]=i;
scanf("%d",&bt[i]);
for(i=0;i<n;i++)
for(k=i+1;k<n;k++)
if(bt[i]>bt[k])
temp=bt[i];
bt[i]=bt[k];
bt[k]=temp;
temp=p[i];
p[i]=p[k];
p[k]=temp;
22701F00I5 Page 3
OS
wt[0]=wtavg=0;
tat[0]=tatavg=bt[0];
for(i=1;i<n;i++)
wt[i]=wt[i-1]+bt[i-1];
tat[i]=tat[i-1]+bt[i];
wtavg=wtavg+wt[i];
tatavg=tatavg+tat[i];
for(i=0;i<n;i++)
printf("\n\tP%d\t\t%d\t\t%d\t\t%d\t\t%d",p[i],bt[i],wt[i],tat[i]);
OUTPUT
22701F00I5 Page 4
OS
P2 2 0 2 0
P3 3 2 5 0
P1 5 5 10 0
P0 6 10 16 0
P4 9 16 25 0
--------------------------------
22701F00I5 Page 5
OS
PRIORITY
#include<stdio.h>
main()
int p[20],bt[20],pri[20],wt[20],tat[20],i,k,n,temp;
float wtavg,tatavg;
scanf("%d",&n);
for(i=0;i<n;i++)
p[i]=i;
scanf("%d%d",&bt[i],&pri[i]);
for(i=0;i<n;i++)
for(k=i+1;k<n;k++)
if(pri[i]>pri[k]);
temp=p[i];
p[i]=p[k];
p[k]=temp;
temp=bt[i];
bt[i]=bt[k];
bt[k]=temp;
temp=pri[i];
22701F00I5 Page 6
OS
pri[i]=pri[k];
pri[k]=temp;
wtavg=wt[0]=0;
tatavg=tat[0]=bt[0];
for(i=1;i<n;i++)
wt[i]=wt[i-1]+bt[i-1];
tat[i]=tat[i-1]+bt[i];
wtavg=wtavg+wt[i];
tatavg=tatavg+tat[i];
for(i=0;i<n;i++)
printf("\n%d\t\t%d\t\t%d\t\t%d\t\t%d",p[i],pri[i],bt[i],wt[i],tat[i]);
OUTPUT
Enter the number of process--5
22701F00I5 Page 7
OS
0 3 10 0 10
1 1 1 10 11
2 4 2 11 13
3 5 1 13 14
4 2 5 14 19
--------------------------------
22701F00I5 Page 8
OS
FILE ALLOCATIONS
A)SEQUENTIAL
#include<stdio.h>
#include<stdlib.h>
main()
int f[50],i,st,j,len,c,k;
for(i=0;i<50;i++)
f[i]=0;
x:
scanf("%d%d",&st,&len);
for(j=st;j<(st+len);j++)
if(f[j]==0)
f[j]=1;
printf("\n%d->%d",j,f[j]);
else
break;
if(j==(st+len))
22701F00I5 Page 9
OS
scanf("%d",&c);
if(c==1)
goto x;
OUTPUT:
10
2->1
3->1
4->1
5->1
6->1
7->1
8->1
9->1
10->1
11->1
22701F00I5 Page 10