// FCFS AVGWAIT
#include<iostream>
using namespace std;
class avg
{
int a[10],s,t,n,w,tt;
public:
void read();
void display();
void awt();
void att();
};
void avg::read()
{
cout<<"enter no of members at theatre counter \n";
cin>>n;
cout<<"enter number of tickets want to purchase \n";
for(int i=0;i<n;i++)
{
cout<<"a["<<i<<"]=";
cin>>a[i];
}
}
void avg::awt()
{ s=0;t=0;
for(int i=0;i<n-1;i++)
{
s=s+a[i];
t=t+s;
}
cout<<"sum of awt is="<<t<<"\n";
w=t/n;
}
void avg::att()
{
t=0;s=0;
for(int i=0;i<n;i++)
{
t=t+a[i];
s=s+t;
}
cout<<"sum of att is="<<s<<"\n";
tt=s/n;
}
void avg::display()
{
cout<<"no of tickets each person will purchase \n";
for(int i=0;i<n;i++)
cout<<"a["<<i<<"]="<<a[i];
cout<<"average waiting time is"<<w<<"\n";
cout<<"average turn over time is"<<tt<<"\n";
}
int main()
{
avg ob;
ob.read();
ob.awt();
ob.att();
ob.display();
return 0;
}
// SJF sjf1.cpp
#include<iostream>
using namespace std;
class sjf
{
int a[10];
float w,tt,s,t,n;
public:
void read();
void display();
void awt();
void att();
void sort();
};
void sjf::read()
{
cout<<"enter no of processors \n";
cin>>n;
cout<<"enter the cpu burst time for each processor \n";
for(int i=0;i<n;i++)
{
cout<<"a["<<i<<"]=";
cin>>a[i];
}
}
void sjf::sort()
{
int x;
cout<<"before sorting\n";
for(int i=0;i<n;i++)
cout<<"a["<<i<<"]="<<a[i];
cout<<"after sorting\n";
for(int j=0;j<n-1;j++)
{
for(int i=0;i<n-j-1;i++)
{
if(a[i]>a[i+1])
{
x=a[i];
a[i]=a[i+1];
a[i+1]=x;
}
}
}
for(int i=0;i<n;i++)
cout<<"a["<<i<<"]="<<a[i];
}
void sjf::awt()
{ s=0;t=0;
for(int i=0;i<n-1;i++)
{
s=s+a[i];
t=t+s;
}
cout<<"sum of awt is="<<t<<"\n";
w=t/n;
}
void sjf::att()
{
t=0;s=0;
for(int i=0;i<n;i++)
{
t=t+a[i];
s=s+t;
}
cout<<"sum of att is="<<s<<"\n";
tt=s/n;
}
void sjf::display()
{
cout<<"the cpu burst time for each processor is \n";
for(int i=0;i<n;i++)
cout<<"a["<<i<<"]="<<a[i];
cout<<"average waiting time is"<<w<<"\n";
cout<<"average turn over time is"<<tt<<"\n";
}
int main()
{
sjf ob;
ob.read();
ob.sort();
ob.awt();
ob.att();
ob.display();
return 0;
}
// Sjf With Arrival Time
#include<iostream>
using namespace std;
class avg
{
int a[10],b[10];
float w,tt,s,t,n;
int n,Bu[20];
float Twt,Awt,A[10],Wt[10],w;
public:
void Getdata();
void Sjf();
void SjfP();
void display();
};
void avg::Getdata()
{
int i;
cout<<"Enter the no of processes:";
cin>>n;
for(i=1;i<=n;i++)
{
cout<<"Enter The BurstTime for Process p"<<i<<"= ";
cin>>Bu[i];
}
}
void avg::Sjf()
{
int i,j,temp,B[10];
Twt=0.0;
for(i=1;i<=n;i++)
{
B[i]=Bu[i];
cout<<"Burst time for process p"<<i<<"= ";
cout<<B[i];
}
for(i=n;i>=1;i--)
{
for(j=1;j<=n;j++)
{
if(B[j-1]>B[j])
{
temp=B[j-1];
B[j-1]=B[j];
B[j]=temp;
}
}
}
Wt[1]=0;
for(i=2;i<=n;i++)
{
Wt[i]=B[i-1]+Wt[i-1];
}
for(i=1;i<=n;i++)
Twt=Twt+Wt[i];
Awt=Twt/n;
cout<<"Total Weighting Time="<<Twt;
cout<<"Average Weighting Time="<<Awt<<"";
}
void cpuschedule::SjfP()
{
int i,j,m,Wt[10],k,B[10],A[10],Tt=0,Wtm[10],temp;
char S[20],start[20];
int max=0,Time=0,min;
float Twt=0.0,Awt;
for(i=1;i<=n;i++)
{
B[i]=Bu[i];
cout<<"Burst time for process P"<<i<<"= "<<B[i];
if(B[i]>max)
max=B[i];
Wt[i]=0;
S[i]='T';
start[i]='F';
Tt=Tt+B[i];
cout<<"Enter the Arrival Time for"<<i<<"th process= ";
cin>>A[i];
if(A[i]>Time)
Time=A[i];
}
cout<<"Max="<<max;
int w=0,flag=0,t=0;
i=1;
while(t<Time)
{
if(A[i]<=t && B[i]!=0)
{
if(flag==0)
{
Wt[i]=Wt[i]+w;
cout<<"Wt["<<i<<"]="<<Wt[i];
}
B[i]=B[i]-1;
if(B[i]==0)
S[i]='F';
start[i]='T';
t++;
w=w+1;
if(S[i]!='F')
{
j=1;flag=1;
while(j<=n && flag!=0)
{
if(S[j]!='F' && B[i]>B[j] && A[j]<=t && i!=j )
{
flag=0;
Wt[i]=Wt[i]-w;
i=j;
}
else
{
flag=1;
}
j++;
}
}
else
{
i++;
j=1;
while(A[j]<=t &&j<=n)
{
if(B[i]>B[j] && S[j]!='F')
{
flag=0;
i=j;
}
j++;
}
}
}
else
if(flag==0)
i++;
}
cout<<"Printing remaining burst time";
for(i=1;i<=n;i++)
cout<<"B["<<i<<"]="<<B[i];
cout<<"";
while(w<Tt)
{
min=max+1;
i=1;
while(i<=n)
{
if(min>B[i] && S[i]=='T')
{
min=B[i];
j=i;
}
i++;
}
i=j;
if(w==Time && start[i]=='T')
{
w=w+B[i];
S[i]='F';
}
else
{
Wt[i]=Wt[i]+w;
w=w+B[i];
S[i]='F';
}
}
cout<<"Weight info";
for(i=1;i<=n;i++)
cout<<"WT["<<i<<"]="<<Wt[i];
cout<<"after subtracting arrival time";
for(i=1;i<=n;i++)
{
Wt[i]=Wt[i]-A[i];
cout<<"WT["<<i<<"]="<<Wt[i];
}
for(i=1;i<=n;i++)
Twt=Twt+Wt[i];
Awt=Twt/n;
cout<<"Average Weighting Time="<<Awt;
}
int main()
{
avg ob;
ob.getdata();
b.sjf();
ob.sjfp();
ob.display();
return 0;
}
// PRIORITY priority.cpp
#include<iostream>
using namespace std;
class schedule
{
int n,Bu[20];
float Twt,Awt,Wt[10],w,Att,Ttt;
public:
//Getting the No of processes & burst time
void Getdata();
void Priority();
};
void schedule::Getdata()
{
int i;
cout<<"Enter the no of processes:";
cin>>n;
for(i=1;i<=n;i++)
{
cout<<"Enter The BurstTime for Process p"<<i<<"= ";
cin>>Bu[i];
}
}
void schedule::Priority()
{
int i,B[10],P[10],j;
w=0.0;
int max;
Twt=0.0;
max=1;
for(i=1;i<=n;i++)
{
B[i]=Bu[i];
cout<<"Burst time for process p"<<i<<"= ";
cout<<B[i];
cout<<"Enter the priority for process P"<<i<<"= ";
cin>>P[i];
if(max<P[i])
max=P[i];
}
j=1;
while(j<=max)
{
i=1;
while(i<=n)
{
if(P[i]==j)
{
Wt[i]=w;
w=w+B[i];
}
i++;
}
j++;
}
//calculating average weighting Time
for(i=1;i<=n;i++)
Twt=Twt+Wt[i];
Awt=Twt/n;
cout<<"Total Weighting Time="<<Twt<<"";
cout<<"Average Weighting Time="<<Awt<<"";
//calculating turn over time
for(i=1;i<=n+1;i++)
Ttt=Ttt+Wt[i];
Att=Ttt/n;
cout<<"Total Turn over Time="<<Ttt<<"";
cout<<"Average Turn over Time="<<Att<<"";
}
int main()
{
int ch,cho;
schedule c;
do
{
cout<<" MENU\n";
cout<<"1.Getting BurstTime";
cout<<"2.Priority";
cout<<"3.EXIT";
cout<<"Enter your choice";
cin>>ch;
switch(ch)
{
case 1:
c.Getdata();
break;
case 2:
cout<<"PRIORITY SCHEDULING";
c.Priority();
break;
case 3:
break;
}
}while(ch<=2);
}
// RoundR.cpp
#include<iostream>
using namespace std;
class RoundR
{
int n,Bu[20];
float Twt,Awt,A[10],Wt[10],w;
public:
void Getdata();
void roundrobin();
};
void RoundR::Getdata()
{
int i;
cout<<"Enter the no of processes:";
cin>>n;
for(i=1;i<=n;i++)
{
cout<<"Enter The BurstTime for Process p"<<i<<"= ";
cin>>Bu[i];
}
}
void RoundR::roundrobin()
{
int i,j,tq,k,B[10],Rrobin[10][10],count[10];
int max=0;
int m;
Twt=0.0;
for(i=1;i<=n;i++)
{
B[i]=Bu[i];
cout<<"Burst time for process p"<<i<<"= ";
cout<<B[i];
if(max<B[i])
max=B[i];
Wt[i]=0;
}
cout<<"Enter the Time Quantum=";
cin>>tq;
m=max/tq+1;
for(i=1;i<=n;i++)
{
for(j=1;j<=m;j++)
{
Rrobin[i][j]=0;
}
}
i=1;
while(i<=n)
{
j=1;
while(B[i]>0)
{
if(B[i]>=tq)
{
B[i]=B[i]-tq;
Rrobin[i][j]=tq;
j++;
}
else
{
Rrobin[i][j]=B[i];
B[i]=0;
j++;
}
}
count[i]=j-1;
i++;
}
cout<<"Display";
for(i=1;i<=n;i++)
{
for(j=1;j<=m;j++)
{
cout<<"Rr["<<i<<","<<j<<"]="<<Rrobin[i][j];
cout<<" ";
}
cout<<" ";
}
//calculating weighting time
int x=1;
i=1;
while(x<=n)
{
for(int a=1;a<x;a++)
{
Wt[x]=Wt[x]+Rrobin[a][i];
}
i=1;
int z=x,tt;
j=count[z];
k=1;
while(k<=j-1)
{
if(i==n+1)
{
i=1;
k++;
}
else
{
if(i!=z)
{
Wt[z]=Wt[z]+Rrobin[i][k];
}
i++;
}
}
x++;
}
for(i=1;i<=n;i++)
cout<<"Weighting Time for process P"<<i<<"="<<Wt[i];
//calculating Average Weighting Time
for(i=1;i<=n;i++)
Twt=Twt+Wt[i];
Awt=Twt/n;
cout<<"Total Weighting Time="<<Twt;
cout<<"Average Weighting Time="<<Awt<<"";
}
int main()
{
RoundR ob;
ob.Getdata();
ob.roundrobin();
return 0;
}
// ROUNDROBIN roundrobin.cpp
#include<iostream>
using namespace std;
class roundrobin
{
public:
int a[100],b[100],c[100],d[100],e[100],m,p;
void getinfo();
void calculations();
float n;
};
void roundrobin::getinfo()
{
cout<<"enter the no of processes\n";
cin>>n;
cout<<"enter each process burstime\n";
for(int i=0;i<n;i++)
{
cin>>a[i];
d[i]=a[i];
}
cout<<"enter the quantum time\n";
cin>>m;
}
void roundrobin::calculations()
{
int s=0;
for(int i=0;i<n;i++)
c[i]=0;
for(int i=0;i<n;i++)
{
if(a[i]%m==0)
s=s+a[i]/m;
else
s=s+(a[i]/m+1);
}
cout<<" the number titrations " << s <<"\n";
int i=0,j=0;
while(i<s)
{
if(j==n)
{
j=0;
}
else
{
if(a[j]==0)
j++;
else if(a[j]>m)
{
b[i++]=m;
a[j++]=a[j]-m;
}
else if(a[j]==m)
{
b[i++]=m;
int sum=0;
for(int k=0;k<i;k++)
sum=sum+b[k];
c[j]=sum-d[j];
e[j]=sum;
a[j++]=0;
}
else if(a[j]<m)
{
b[i++]=a[j];
int sum=0;
for(int k=0;k<i;k++)
sum=sum+b[k];
c[j]=sum-d[j];
e[j]=sum;
a[j++]=0;
}
}
}
cout<<"\n";
for(int i=0;i<s;i++)
cout<<b[i]<<"\t";
cout<<"\n";
float awt,att; int wt=0,tt=0;
for(int i=0;i<n;i++)
wt=wt+c[i];
awt=wt/n;
cout<<"average waiting time is:"<<awt<<"\n";
for(int i=0;i<n;i++)
tt=tt+e[i];
att=tt/n;
cout<<"\naverage turn around time is:"<<att<<"\n";
}
int main()
{
roundrobin r;
r.getinfo();
r.calculations();
}
// vi bankers.cpp
#include<iostream>
using namespace std;
class bankalg
{
int **alloc;
int **max;
int *work;
int *avail;
int **need;
int *safe;
int *flag;
int p,r;
public:
void read();
void safe_sequence();
void request_resource();
};
void bankalg::read()
{
int i,j;
cout<<"\nEnter the total number of processes\n";
cin>>p;
cout<<"\nEnter the number of resource types\n";
cin>>r;
alloc=new int* [p];
max=new int* [p];
need=new int* [p];
avail=new int[r];
work=new int[r];
for(i=0;i<p;i++)
{
alloc[i]=new int[r];
max[i]=new int[r];
need[i]=new int[r];
}
cout<<"\nEnter the allocated resources of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>alloc[i][j];
}
cout<<"\nEnter the Maximum number of resources for each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>max[i][j];
}
cout<<"\nEnter the available resources of each type\n";
for(i=0;i<r;i++)
cin>>avail[i];
for(i=0;i<r;i++)
work[i]=avail[i];
}
void bankalg::safe_sequence()
{
int i,j;
safe=new int[p];
flag=new int[p];
for(i=0;i<p;i++)
{
flag[i]=0;
}
for(i=0;i<p;i++)
for(j=0;j<r;j++)
need[i][j]=max[i][j]-alloc[i][j];
int l=0;
for(int z=0;z<(p*p);z++)
{
for(int i=0;i<p;i++)
{ if(flag[i]==0)
{
j=0;
while(j<r)
{ if(need[i][j]<=avail[j])
{
if(j==r-1)
{ flag[i]=1;
for(int k=0;k<r;k++)
avail[k]+=alloc[i][k];
safe[l++]=i;
cout<<"\n"<<i<<"\n";
} j++;
}
else break;
}
}
}
for(int i=0;i<p;i++)
{
if(flag[i]==1)
{ if(i==r-1)
{
cout<<"\nThe safe sequence is:\n";
for(j=0;j<p;j++)
cout<<"P"<<safe[j]<<" ";
return;
}
}
}
}
cout<<"\nSystem is not in safe state\n";
}
void bankalg::request_resource()
{
int m;
int *request=new int[r];
cout<<"Enter the the new request:\nProcess which is requesting:";
cin>>m;
cout<<"Request:";
for(int i=0;i<r;i++)
cin>>request[i];
int i=0;
while(i<r)
{
if(request[i]<=need[m][i])
i++;
else
{
cout<<"Error.";
exit(1);
}
}
i=0;
while(i<r)
{
if(request[i]<avail[i])
i++;
else
break;
}
if(i==3)
{
for(int i=0;i<r;i++)
avail[i]=work[i];
for(int i=0;i<r;i++)
{
avail[i]=avail[i]-request[i];
alloc[m][i]+=request[i];
need[m][i]-=request[i];
}
safe_sequence();
}
else
cout<<"Request cannot be granted.";
}
int main()
{
int choice;
bankalg ob;
ob.read();
ob.safe_sequence();
cout<<"\nIf you want to enter a new request press 1. Else press 2.\n";
cin>>choice;
switch(choice)
{
case 1:ob.request_resource();
break;
case 2:exit(1);
}
}
// Detection algorithm
#include<iostream>
using namespace std;
class bankalg
{
int **alloc;
int **request;
int *work;
int *avail;
int *safe;
int *flag;
int p,r;
public:
void read();
void safe_sequence();
void request_resource();
};
void bankalg::read()
{
int i,j;
cout<<"\nEnter the total number of processes\n";
cin>>p;
cout<<"\nEnter the number of resource types\n";
cin>>r;
alloc=new int* [p];
request=new int* [p];
avail=new int[r];
work=new int[r];
for(i=0;i<p;i++)
{
alloc[i]=new int[r];
request[i]=new int[r];
}
cout<<"\nEnter the allocated resources of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>alloc[i][j];
}
cout<<"\nEnter the request of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>request[i][j];
}
cout<<"\nEnter the available resources of each type\n";
for(i=0;i<r;i++)
cin>>avail[i];
for(i=0;i<r;i++)
work[i]=avail[i];
}
void bankalg::safe_sequence()
{
int i,j;
safe=new int[p];
flag=new int[p];
for(i=0;i<p;i++)
{
flag[i]=0;
}
int l=0;
for(int z=0;z<(p*p);z++)
{
for(int i=0;i<p;i++)
{ if(flag[i]==0)
{
j=0;
while(j<r)
{ if(request[i][j]<=avail[j])
{
if(j==r-1)
{ flag[i]=1;
for(int k=0;k<r;k++)
avail[k]+=alloc[i][k];
safe[l++]=i;
cout<<"\n"<<i<<"\n";
} j++;
}
else break;
}
}
}
for(int i=0;i<p;i++)
{
if(flag[i]==1)
{ if(i==r-1)
{
cout<<"\nThe safe sequence is:\n";
for(j=0;j<p;j++)
cout<<"P"<<safe[j]<<" ";
return;
}
}
else break;
}
}
cout<<"\nSystem is not in safe state\n";
}
void bankalg::request_resource()
{
int *req=new int[r];
int m;
cout<<"Enter the the new request:\nProcess which is requesting:";
cin>>m;
cout<<"Request:";
for(int i=0;i<r;i++)
{
cin>>req[i];
request[m][i]+=req[i];
}
for(int i=0;i<r;i++)
avail[i]=work[i];
safe_sequence();
}
int main()
{
int choice;
bankalg ob;
ob.read();
ob.safe_sequence();
cout<<"\nIf you want to enter a new request press 1. Else press 2.\n";
cin>>choice;
switch(choice)
{
case 1:ob.request_resource();
break;
case 2:exit(1);
}
}
// FIFO
#include<stdio.h>
main()
{
int p[20],i,j=0,k,l=0,n,m,q[5],fault=0,z=0;
printf("\nEnter num of pages:");
scanf("%d",&n);
printf("enter pages:");
for(i=0;i<n;i++)
scanf("%d",&p[i]);
printf("\n enter num of frames:");
scanf("%d",&m);
for(i=0;i<m;i++)
q[i]=-1;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
if(p[i]==q[j])
z++;
if(z==0)
{
fault++;
l=l%m;
q[l]=p[i];
l++;
z=0;
for(k=0;k<m;k++)
printf("%d\t",q[k]);
printf("\n");
}
z=0;
}
printf("Number of page faults:%d",fault);
}
//INPUT: 20 7 0 1 2 0 3 0 4 2 3 0 3 2 1 2 0 1 7 0 1 3
//INPUT2: 12 1 2 3 4 1 2 5 1 2 3 4 5 3
// LRU
#include<stdio.h>
main()
{
int p[20],i,j=0,k,l=0,n,m,q[5],fault=0,z=0 ,x[3],max=0,c,b,a;
printf("\n enter the num of pages:");
scanf("%d",&n);
printf("enter pages:");
for(i=0;i<n;i++)
scanf("%d",&p[i]);
printf("enter no of frames:");
scanf("%d",&m);
for(i=0;i<m;i++)
q[i]=-1;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
if(p[i]==q[j])
z++;
if(z==0)
{
fault++;
if(i>m-1)
{
for(a=0;a<m;a++)
x[a]=0;
for(c=0;c<m;c++)
for(b=i;b>=0;b--)
{
if(q[c]!=p[b])
x[c]++;
else
break;
}
max=x[0];l=0;
if(x[1]>max){ max=x[1];l=1;}
if(x[2]>max){ max=x[2];l=2;}
}
q[l]=p[i];
l++;
z=0;
for(k=0;k<m;k++)
printf("%d\t",q[k]);
printf("\n");
}
z=0;
}
printf("no. of page faults:%d",fault);
}
// PAGING paging.c
#include<math.h>
#include<stdio.h>
int split(int *c,int n)
{
int a,b,i,k=0,sum=0;
if(n==1)
{
a=0;b=1;
}
else
{
a=2;b=3;
}
for(i=b;i>=a;i--)
{
sum=sum+(c[i]*pow(2,k));
k++;
}
return(sum);
}
void binary(int sum,int *c)
{
int d,i=3,n;
n=sum;
while(n>0)
{
d=n%2;
c[i]=d;
n=n/2;
i--;
}
}
int main()
{
int a[10],k,i,j,n,temp1,temp2,b[10],c[4],d[32];
for(i=0;i<16;i++)
a[i]=i+65;
for(i=0;i<32;i++)
d[i]=32;
printf("\n\n how many values do u want to enter in page table:");
scanf("%d",&n);
printf("\n\n enter the page table\n\n");
for(i=0;i<n;i++)
scanf("%d",&b[i]);
for(i=0;i<16;i++)
{
for(j=0;j<4;j++)
c[j]=0;
binary(i,&c[0]);
temp1=split(&c[0],1);
temp2=split(&c[0],3);
n=(b[temp1]*4)+temp2;
d[n]=i+65;
}
printf("\n\n\n\t\tpage table\n\n");
for(i=0;i<32;i++)
{
printf("\n address %d \t value %c",i,d[i]);
}
}
// OPTIMAL optimal.c
#include<stdio.h>
main()
{
int p[20],i,j=0,k,l=0,n,m,q[5],fault=0,z=0,x[3],max=0,c,b,a;
printf("\n enter the num of pages:");
scanf("%d",&n);
printf("enter pages:");
for(i=0;i<n;i++)
scanf("%d",&p[i]);
printf("enter no of frames:");
scanf("%d",&m);
for(i=0;i<m;i++)
q[i]=-1;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
if(p[i]==q[j])
z++;
if(z==0)
{
fault++;
if(i>m-1)
{
for(a=0;a<m;a++)
x[a]=0;
for(c=0;c<m;c++)
for(b=i;b<n;b++)
{
if(q[c]!=p[b])
x[c]++;
else
break;
}
max=x[0];l=0;
if(x[1]>max){ max=x[1];l=1;}
if(x[2]>max){ max=x[2];l=2;}
}
q[l]=p[i];
l++;
z=0;
for(k=0;k<m;k++)
printf("%d\t",q[k]);
printf("\n");
}
z=0;
}
printf("No. of page faults:%d",fault);
}
// MFT
#include<stdio.h>
main()
{
int ms,choice,size,nb,i,j,frag;
static int sz[20][2],nj,s;
int count=0;
static int jobs[20][3];
printf("enter memory space:\n");
scanf("%d",&ms);
printf("enter your choice:");
printf("\n enter \n 1.equal partition \n 2.unequal partition");
scanf("%d",&choice);
if(choice==1)
{
printf("enter size of each block:");
scanf("%d",&s);
nb=ms/s;
for(i=0;i<nb;i++)
sz[i][0]=s;
printf("total no. of blocks: %d\n",nb);
}
else
{
printf("enter no. of blocks:\n");
scanf("%d",&nb);
for(i=0;i<nb;i++)
{
printf("enter size of %d block:\n",i);
scanf("%d",&sz[i][0]);
}
}
printf("enter no. of jobs:\n");
scanf("%d",&nj);
printf("enter job info \n 1.job id \n 2.job size\n");
for(i=0;i<nj;i++)
scanf("%d%d",&jobs[i][0],&jobs[i][1]);
frag=0;
for(i=0;i<nj;i++)
{
if(jobs[i][1]<sz[i][0])
{
jobs[i][2]=2;
frag+=sz[i][0]-jobs[i][1];
count+=1;
}
}
printf("total internal fragmentation is %d\n",frag);
printf("no. of free blocks:%d\n",nb-count);
printf("the jobs which are not allocated:");
if(count==nj)
printf("0");
for(i=0;i<nj;i++)
{
if(jobs[i][2]!=2)
printf("\n job id-> %d \n job size-> %d",jobs[i][0],jobs[i][1]);
}
}
// MVT mvt.c
#include<stdio.h>
main()
{
static int jobs[20][2],flag[10],i,k,nj,nb=0,tms,ch;
printf("Enter no. of jobs:");
scanf("%d",&nj);
printf("Enter total memory space:");
scanf("%d",&tms);
printf("Enter job info:\n1.Job id\n2.Job size\n");
for(i=0;i<nj;i++)
scanf("%d%d",&jobs[i][0],&jobs[i][1]);
for(i=0;i<nj;i++)
{
if(tms>=jobs[i][1])
{
nb=nb+1;
tms=tms-jobs[i][1];
flag[i]=1;
}
}
printf("Free space after allocation is %d",tms);
printf("\nThe allocated jobs are:\n");
for(i=0;i<nj;i++)
if(flag[i]==1)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
printf("\nJobs which are not allocated are:\n");
for(i=0;i<nj;i++)
if(flag[i]==0)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
if(nb!=nj)
{
while(1)
{
printf("Enter the job id to deallocate:\n");
scanf("%d",&k);
for(i=0;i<nj;i++)
if(jobs[i][0]==k)
if(flag[i]==1)
{
tms=tms+jobs[i][1];
flag[i]=2;
printf("The deallocated job is \n%d->%d",jobs[i][0],jobs[i][1]);
}
for(i=0;i<nj;i++)
if(tms>=jobs[i][1])
if(flag[i]==0)
{
tms=tms-jobs[i][1];
flag[i]=1;
}
printf("\nThe allocated jobs are:\n");
for(i=0;i<nj;i++)
if(flag[i]==1)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
printf("Jobs which are not allocated are:");
for(i=0;i<nj;i++)
if(flag[i]==0||flag[i]==2)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
printf("\nFree space after allocating is %d",tms);
printf("\nDo you want to deallocate\n1.Yes\n2.No\n");
scanf("%d",&ch);
if(ch==2)
break;
}
}
printf("Allocated jobs are:\n");
for(i=0;i<nj;i++)
if(flag[i]==1)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
}
#include<iostream>
using namespace std;
class avg
{
int a[10],s,t,n,w,tt;
public:
void read();
void display();
void awt();
void att();
};
void avg::read()
{
cout<<"enter no of members at theatre counter \n";
cin>>n;
cout<<"enter number of tickets want to purchase \n";
for(int i=0;i<n;i++)
{
cout<<"a["<<i<<"]=";
cin>>a[i];
}
}
void avg::awt()
{ s=0;t=0;
for(int i=0;i<n-1;i++)
{
s=s+a[i];
t=t+s;
}
cout<<"sum of awt is="<<t<<"\n";
w=t/n;
}
void avg::att()
{
t=0;s=0;
for(int i=0;i<n;i++)
{
t=t+a[i];
s=s+t;
}
cout<<"sum of att is="<<s<<"\n";
tt=s/n;
}
void avg::display()
{
cout<<"no of tickets each person will purchase \n";
for(int i=0;i<n;i++)
cout<<"a["<<i<<"]="<<a[i];
cout<<"average waiting time is"<<w<<"\n";
cout<<"average turn over time is"<<tt<<"\n";
}
int main()
{
avg ob;
ob.read();
ob.awt();
ob.att();
ob.display();
return 0;
}
// SJF sjf1.cpp
#include<iostream>
using namespace std;
class sjf
{
int a[10];
float w,tt,s,t,n;
public:
void read();
void display();
void awt();
void att();
void sort();
};
void sjf::read()
{
cout<<"enter no of processors \n";
cin>>n;
cout<<"enter the cpu burst time for each processor \n";
for(int i=0;i<n;i++)
{
cout<<"a["<<i<<"]=";
cin>>a[i];
}
}
void sjf::sort()
{
int x;
cout<<"before sorting\n";
for(int i=0;i<n;i++)
cout<<"a["<<i<<"]="<<a[i];
cout<<"after sorting\n";
for(int j=0;j<n-1;j++)
{
for(int i=0;i<n-j-1;i++)
{
if(a[i]>a[i+1])
{
x=a[i];
a[i]=a[i+1];
a[i+1]=x;
}
}
}
for(int i=0;i<n;i++)
cout<<"a["<<i<<"]="<<a[i];
}
void sjf::awt()
{ s=0;t=0;
for(int i=0;i<n-1;i++)
{
s=s+a[i];
t=t+s;
}
cout<<"sum of awt is="<<t<<"\n";
w=t/n;
}
void sjf::att()
{
t=0;s=0;
for(int i=0;i<n;i++)
{
t=t+a[i];
s=s+t;
}
cout<<"sum of att is="<<s<<"\n";
tt=s/n;
}
void sjf::display()
{
cout<<"the cpu burst time for each processor is \n";
for(int i=0;i<n;i++)
cout<<"a["<<i<<"]="<<a[i];
cout<<"average waiting time is"<<w<<"\n";
cout<<"average turn over time is"<<tt<<"\n";
}
int main()
{
sjf ob;
ob.read();
ob.sort();
ob.awt();
ob.att();
ob.display();
return 0;
}
// Sjf With Arrival Time
#include<iostream>
using namespace std;
class avg
{
int a[10],b[10];
float w,tt,s,t,n;
int n,Bu[20];
float Twt,Awt,A[10],Wt[10],w;
public:
void Getdata();
void Sjf();
void SjfP();
void display();
};
void avg::Getdata()
{
int i;
cout<<"Enter the no of processes:";
cin>>n;
for(i=1;i<=n;i++)
{
cout<<"Enter The BurstTime for Process p"<<i<<"= ";
cin>>Bu[i];
}
}
void avg::Sjf()
{
int i,j,temp,B[10];
Twt=0.0;
for(i=1;i<=n;i++)
{
B[i]=Bu[i];
cout<<"Burst time for process p"<<i<<"= ";
cout<<B[i];
}
for(i=n;i>=1;i--)
{
for(j=1;j<=n;j++)
{
if(B[j-1]>B[j])
{
temp=B[j-1];
B[j-1]=B[j];
B[j]=temp;
}
}
}
Wt[1]=0;
for(i=2;i<=n;i++)
{
Wt[i]=B[i-1]+Wt[i-1];
}
for(i=1;i<=n;i++)
Twt=Twt+Wt[i];
Awt=Twt/n;
cout<<"Total Weighting Time="<<Twt;
cout<<"Average Weighting Time="<<Awt<<"";
}
void cpuschedule::SjfP()
{
int i,j,m,Wt[10],k,B[10],A[10],Tt=0,Wtm[10],temp;
char S[20],start[20];
int max=0,Time=0,min;
float Twt=0.0,Awt;
for(i=1;i<=n;i++)
{
B[i]=Bu[i];
cout<<"Burst time for process P"<<i<<"= "<<B[i];
if(B[i]>max)
max=B[i];
Wt[i]=0;
S[i]='T';
start[i]='F';
Tt=Tt+B[i];
cout<<"Enter the Arrival Time for"<<i<<"th process= ";
cin>>A[i];
if(A[i]>Time)
Time=A[i];
}
cout<<"Max="<<max;
int w=0,flag=0,t=0;
i=1;
while(t<Time)
{
if(A[i]<=t && B[i]!=0)
{
if(flag==0)
{
Wt[i]=Wt[i]+w;
cout<<"Wt["<<i<<"]="<<Wt[i];
}
B[i]=B[i]-1;
if(B[i]==0)
S[i]='F';
start[i]='T';
t++;
w=w+1;
if(S[i]!='F')
{
j=1;flag=1;
while(j<=n && flag!=0)
{
if(S[j]!='F' && B[i]>B[j] && A[j]<=t && i!=j )
{
flag=0;
Wt[i]=Wt[i]-w;
i=j;
}
else
{
flag=1;
}
j++;
}
}
else
{
i++;
j=1;
while(A[j]<=t &&j<=n)
{
if(B[i]>B[j] && S[j]!='F')
{
flag=0;
i=j;
}
j++;
}
}
}
else
if(flag==0)
i++;
}
cout<<"Printing remaining burst time";
for(i=1;i<=n;i++)
cout<<"B["<<i<<"]="<<B[i];
cout<<"";
while(w<Tt)
{
min=max+1;
i=1;
while(i<=n)
{
if(min>B[i] && S[i]=='T')
{
min=B[i];
j=i;
}
i++;
}
i=j;
if(w==Time && start[i]=='T')
{
w=w+B[i];
S[i]='F';
}
else
{
Wt[i]=Wt[i]+w;
w=w+B[i];
S[i]='F';
}
}
cout<<"Weight info";
for(i=1;i<=n;i++)
cout<<"WT["<<i<<"]="<<Wt[i];
cout<<"after subtracting arrival time";
for(i=1;i<=n;i++)
{
Wt[i]=Wt[i]-A[i];
cout<<"WT["<<i<<"]="<<Wt[i];
}
for(i=1;i<=n;i++)
Twt=Twt+Wt[i];
Awt=Twt/n;
cout<<"Average Weighting Time="<<Awt;
}
int main()
{
avg ob;
ob.getdata();
b.sjf();
ob.sjfp();
ob.display();
return 0;
}
// PRIORITY priority.cpp
#include<iostream>
using namespace std;
class schedule
{
int n,Bu[20];
float Twt,Awt,Wt[10],w,Att,Ttt;
public:
//Getting the No of processes & burst time
void Getdata();
void Priority();
};
void schedule::Getdata()
{
int i;
cout<<"Enter the no of processes:";
cin>>n;
for(i=1;i<=n;i++)
{
cout<<"Enter The BurstTime for Process p"<<i<<"= ";
cin>>Bu[i];
}
}
void schedule::Priority()
{
int i,B[10],P[10],j;
w=0.0;
int max;
Twt=0.0;
max=1;
for(i=1;i<=n;i++)
{
B[i]=Bu[i];
cout<<"Burst time for process p"<<i<<"= ";
cout<<B[i];
cout<<"Enter the priority for process P"<<i<<"= ";
cin>>P[i];
if(max<P[i])
max=P[i];
}
j=1;
while(j<=max)
{
i=1;
while(i<=n)
{
if(P[i]==j)
{
Wt[i]=w;
w=w+B[i];
}
i++;
}
j++;
}
//calculating average weighting Time
for(i=1;i<=n;i++)
Twt=Twt+Wt[i];
Awt=Twt/n;
cout<<"Total Weighting Time="<<Twt<<"";
cout<<"Average Weighting Time="<<Awt<<"";
//calculating turn over time
for(i=1;i<=n+1;i++)
Ttt=Ttt+Wt[i];
Att=Ttt/n;
cout<<"Total Turn over Time="<<Ttt<<"";
cout<<"Average Turn over Time="<<Att<<"";
}
int main()
{
int ch,cho;
schedule c;
do
{
cout<<" MENU\n";
cout<<"1.Getting BurstTime";
cout<<"2.Priority";
cout<<"3.EXIT";
cout<<"Enter your choice";
cin>>ch;
switch(ch)
{
case 1:
c.Getdata();
break;
case 2:
cout<<"PRIORITY SCHEDULING";
c.Priority();
break;
case 3:
break;
}
}while(ch<=2);
}
// RoundR.cpp
#include<iostream>
using namespace std;
class RoundR
{
int n,Bu[20];
float Twt,Awt,A[10],Wt[10],w;
public:
void Getdata();
void roundrobin();
};
void RoundR::Getdata()
{
int i;
cout<<"Enter the no of processes:";
cin>>n;
for(i=1;i<=n;i++)
{
cout<<"Enter The BurstTime for Process p"<<i<<"= ";
cin>>Bu[i];
}
}
void RoundR::roundrobin()
{
int i,j,tq,k,B[10],Rrobin[10][10],count[10];
int max=0;
int m;
Twt=0.0;
for(i=1;i<=n;i++)
{
B[i]=Bu[i];
cout<<"Burst time for process p"<<i<<"= ";
cout<<B[i];
if(max<B[i])
max=B[i];
Wt[i]=0;
}
cout<<"Enter the Time Quantum=";
cin>>tq;
m=max/tq+1;
for(i=1;i<=n;i++)
{
for(j=1;j<=m;j++)
{
Rrobin[i][j]=0;
}
}
i=1;
while(i<=n)
{
j=1;
while(B[i]>0)
{
if(B[i]>=tq)
{
B[i]=B[i]-tq;
Rrobin[i][j]=tq;
j++;
}
else
{
Rrobin[i][j]=B[i];
B[i]=0;
j++;
}
}
count[i]=j-1;
i++;
}
cout<<"Display";
for(i=1;i<=n;i++)
{
for(j=1;j<=m;j++)
{
cout<<"Rr["<<i<<","<<j<<"]="<<Rrobin[i][j];
cout<<" ";
}
cout<<" ";
}
//calculating weighting time
int x=1;
i=1;
while(x<=n)
{
for(int a=1;a<x;a++)
{
Wt[x]=Wt[x]+Rrobin[a][i];
}
i=1;
int z=x,tt;
j=count[z];
k=1;
while(k<=j-1)
{
if(i==n+1)
{
i=1;
k++;
}
else
{
if(i!=z)
{
Wt[z]=Wt[z]+Rrobin[i][k];
}
i++;
}
}
x++;
}
for(i=1;i<=n;i++)
cout<<"Weighting Time for process P"<<i<<"="<<Wt[i];
//calculating Average Weighting Time
for(i=1;i<=n;i++)
Twt=Twt+Wt[i];
Awt=Twt/n;
cout<<"Total Weighting Time="<<Twt;
cout<<"Average Weighting Time="<<Awt<<"";
}
int main()
{
RoundR ob;
ob.Getdata();
ob.roundrobin();
return 0;
}
// ROUNDROBIN roundrobin.cpp
#include<iostream>
using namespace std;
class roundrobin
{
public:
int a[100],b[100],c[100],d[100],e[100],m,p;
void getinfo();
void calculations();
float n;
};
void roundrobin::getinfo()
{
cout<<"enter the no of processes\n";
cin>>n;
cout<<"enter each process burstime\n";
for(int i=0;i<n;i++)
{
cin>>a[i];
d[i]=a[i];
}
cout<<"enter the quantum time\n";
cin>>m;
}
void roundrobin::calculations()
{
int s=0;
for(int i=0;i<n;i++)
c[i]=0;
for(int i=0;i<n;i++)
{
if(a[i]%m==0)
s=s+a[i]/m;
else
s=s+(a[i]/m+1);
}
cout<<" the number titrations " << s <<"\n";
int i=0,j=0;
while(i<s)
{
if(j==n)
{
j=0;
}
else
{
if(a[j]==0)
j++;
else if(a[j]>m)
{
b[i++]=m;
a[j++]=a[j]-m;
}
else if(a[j]==m)
{
b[i++]=m;
int sum=0;
for(int k=0;k<i;k++)
sum=sum+b[k];
c[j]=sum-d[j];
e[j]=sum;
a[j++]=0;
}
else if(a[j]<m)
{
b[i++]=a[j];
int sum=0;
for(int k=0;k<i;k++)
sum=sum+b[k];
c[j]=sum-d[j];
e[j]=sum;
a[j++]=0;
}
}
}
cout<<"\n";
for(int i=0;i<s;i++)
cout<<b[i]<<"\t";
cout<<"\n";
float awt,att; int wt=0,tt=0;
for(int i=0;i<n;i++)
wt=wt+c[i];
awt=wt/n;
cout<<"average waiting time is:"<<awt<<"\n";
for(int i=0;i<n;i++)
tt=tt+e[i];
att=tt/n;
cout<<"\naverage turn around time is:"<<att<<"\n";
}
int main()
{
roundrobin r;
r.getinfo();
r.calculations();
}
// vi bankers.cpp
#include<iostream>
using namespace std;
class bankalg
{
int **alloc;
int **max;
int *work;
int *avail;
int **need;
int *safe;
int *flag;
int p,r;
public:
void read();
void safe_sequence();
void request_resource();
};
void bankalg::read()
{
int i,j;
cout<<"\nEnter the total number of processes\n";
cin>>p;
cout<<"\nEnter the number of resource types\n";
cin>>r;
alloc=new int* [p];
max=new int* [p];
need=new int* [p];
avail=new int[r];
work=new int[r];
for(i=0;i<p;i++)
{
alloc[i]=new int[r];
max[i]=new int[r];
need[i]=new int[r];
}
cout<<"\nEnter the allocated resources of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>alloc[i][j];
}
cout<<"\nEnter the Maximum number of resources for each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>max[i][j];
}
cout<<"\nEnter the available resources of each type\n";
for(i=0;i<r;i++)
cin>>avail[i];
for(i=0;i<r;i++)
work[i]=avail[i];
}
void bankalg::safe_sequence()
{
int i,j;
safe=new int[p];
flag=new int[p];
for(i=0;i<p;i++)
{
flag[i]=0;
}
for(i=0;i<p;i++)
for(j=0;j<r;j++)
need[i][j]=max[i][j]-alloc[i][j];
int l=0;
for(int z=0;z<(p*p);z++)
{
for(int i=0;i<p;i++)
{ if(flag[i]==0)
{
j=0;
while(j<r)
{ if(need[i][j]<=avail[j])
{
if(j==r-1)
{ flag[i]=1;
for(int k=0;k<r;k++)
avail[k]+=alloc[i][k];
safe[l++]=i;
cout<<"\n"<<i<<"\n";
} j++;
}
else break;
}
}
}
for(int i=0;i<p;i++)
{
if(flag[i]==1)
{ if(i==r-1)
{
cout<<"\nThe safe sequence is:\n";
for(j=0;j<p;j++)
cout<<"P"<<safe[j]<<" ";
return;
}
}
}
}
cout<<"\nSystem is not in safe state\n";
}
void bankalg::request_resource()
{
int m;
int *request=new int[r];
cout<<"Enter the the new request:\nProcess which is requesting:";
cin>>m;
cout<<"Request:";
for(int i=0;i<r;i++)
cin>>request[i];
int i=0;
while(i<r)
{
if(request[i]<=need[m][i])
i++;
else
{
cout<<"Error.";
exit(1);
}
}
i=0;
while(i<r)
{
if(request[i]<avail[i])
i++;
else
break;
}
if(i==3)
{
for(int i=0;i<r;i++)
avail[i]=work[i];
for(int i=0;i<r;i++)
{
avail[i]=avail[i]-request[i];
alloc[m][i]+=request[i];
need[m][i]-=request[i];
}
safe_sequence();
}
else
cout<<"Request cannot be granted.";
}
int main()
{
int choice;
bankalg ob;
ob.read();
ob.safe_sequence();
cout<<"\nIf you want to enter a new request press 1. Else press 2.\n";
cin>>choice;
switch(choice)
{
case 1:ob.request_resource();
break;
case 2:exit(1);
}
}
// Detection algorithm
#include<iostream>
using namespace std;
class bankalg
{
int **alloc;
int **request;
int *work;
int *avail;
int *safe;
int *flag;
int p,r;
public:
void read();
void safe_sequence();
void request_resource();
};
void bankalg::read()
{
int i,j;
cout<<"\nEnter the total number of processes\n";
cin>>p;
cout<<"\nEnter the number of resource types\n";
cin>>r;
alloc=new int* [p];
request=new int* [p];
avail=new int[r];
work=new int[r];
for(i=0;i<p;i++)
{
alloc[i]=new int[r];
request[i]=new int[r];
}
cout<<"\nEnter the allocated resources of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>alloc[i][j];
}
cout<<"\nEnter the request of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>request[i][j];
}
cout<<"\nEnter the available resources of each type\n";
for(i=0;i<r;i++)
cin>>avail[i];
for(i=0;i<r;i++)
work[i]=avail[i];
}
void bankalg::safe_sequence()
{
int i,j;
safe=new int[p];
flag=new int[p];
for(i=0;i<p;i++)
{
flag[i]=0;
}
int l=0;
for(int z=0;z<(p*p);z++)
{
for(int i=0;i<p;i++)
{ if(flag[i]==0)
{
j=0;
while(j<r)
{ if(request[i][j]<=avail[j])
{
if(j==r-1)
{ flag[i]=1;
for(int k=0;k<r;k++)
avail[k]+=alloc[i][k];
safe[l++]=i;
cout<<"\n"<<i<<"\n";
} j++;
}
else break;
}
}
}
for(int i=0;i<p;i++)
{
if(flag[i]==1)
{ if(i==r-1)
{
cout<<"\nThe safe sequence is:\n";
for(j=0;j<p;j++)
cout<<"P"<<safe[j]<<" ";
return;
}
}
else break;
}
}
cout<<"\nSystem is not in safe state\n";
}
void bankalg::request_resource()
{
int *req=new int[r];
int m;
cout<<"Enter the the new request:\nProcess which is requesting:";
cin>>m;
cout<<"Request:";
for(int i=0;i<r;i++)
{
cin>>req[i];
request[m][i]+=req[i];
}
for(int i=0;i<r;i++)
avail[i]=work[i];
safe_sequence();
}
int main()
{
int choice;
bankalg ob;
ob.read();
ob.safe_sequence();
cout<<"\nIf you want to enter a new request press 1. Else press 2.\n";
cin>>choice;
switch(choice)
{
case 1:ob.request_resource();
break;
case 2:exit(1);
}
}
// FIFO
#include<stdio.h>
main()
{
int p[20],i,j=0,k,l=0,n,m,q[5],fault=0,z=0;
printf("\nEnter num of pages:");
scanf("%d",&n);
printf("enter pages:");
for(i=0;i<n;i++)
scanf("%d",&p[i]);
printf("\n enter num of frames:");
scanf("%d",&m);
for(i=0;i<m;i++)
q[i]=-1;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
if(p[i]==q[j])
z++;
if(z==0)
{
fault++;
l=l%m;
q[l]=p[i];
l++;
z=0;
for(k=0;k<m;k++)
printf("%d\t",q[k]);
printf("\n");
}
z=0;
}
printf("Number of page faults:%d",fault);
}
//INPUT: 20 7 0 1 2 0 3 0 4 2 3 0 3 2 1 2 0 1 7 0 1 3
//INPUT2: 12 1 2 3 4 1 2 5 1 2 3 4 5 3
// LRU
#include<stdio.h>
main()
{
int p[20],i,j=0,k,l=0,n,m,q[5],fault=0,z=0 ,x[3],max=0,c,b,a;
printf("\n enter the num of pages:");
scanf("%d",&n);
printf("enter pages:");
for(i=0;i<n;i++)
scanf("%d",&p[i]);
printf("enter no of frames:");
scanf("%d",&m);
for(i=0;i<m;i++)
q[i]=-1;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
if(p[i]==q[j])
z++;
if(z==0)
{
fault++;
if(i>m-1)
{
for(a=0;a<m;a++)
x[a]=0;
for(c=0;c<m;c++)
for(b=i;b>=0;b--)
{
if(q[c]!=p[b])
x[c]++;
else
break;
}
max=x[0];l=0;
if(x[1]>max){ max=x[1];l=1;}
if(x[2]>max){ max=x[2];l=2;}
}
q[l]=p[i];
l++;
z=0;
for(k=0;k<m;k++)
printf("%d\t",q[k]);
printf("\n");
}
z=0;
}
printf("no. of page faults:%d",fault);
}
// PAGING paging.c
#include<math.h>
#include<stdio.h>
int split(int *c,int n)
{
int a,b,i,k=0,sum=0;
if(n==1)
{
a=0;b=1;
}
else
{
a=2;b=3;
}
for(i=b;i>=a;i--)
{
sum=sum+(c[i]*pow(2,k));
k++;
}
return(sum);
}
void binary(int sum,int *c)
{
int d,i=3,n;
n=sum;
while(n>0)
{
d=n%2;
c[i]=d;
n=n/2;
i--;
}
}
int main()
{
int a[10],k,i,j,n,temp1,temp2,b[10],c[4],d[32];
for(i=0;i<16;i++)
a[i]=i+65;
for(i=0;i<32;i++)
d[i]=32;
printf("\n\n how many values do u want to enter in page table:");
scanf("%d",&n);
printf("\n\n enter the page table\n\n");
for(i=0;i<n;i++)
scanf("%d",&b[i]);
for(i=0;i<16;i++)
{
for(j=0;j<4;j++)
c[j]=0;
binary(i,&c[0]);
temp1=split(&c[0],1);
temp2=split(&c[0],3);
n=(b[temp1]*4)+temp2;
d[n]=i+65;
}
printf("\n\n\n\t\tpage table\n\n");
for(i=0;i<32;i++)
{
printf("\n address %d \t value %c",i,d[i]);
}
}
// OPTIMAL optimal.c
#include<stdio.h>
main()
{
int p[20],i,j=0,k,l=0,n,m,q[5],fault=0,z=0,x[3],max=0,c,b,a;
printf("\n enter the num of pages:");
scanf("%d",&n);
printf("enter pages:");
for(i=0;i<n;i++)
scanf("%d",&p[i]);
printf("enter no of frames:");
scanf("%d",&m);
for(i=0;i<m;i++)
q[i]=-1;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
if(p[i]==q[j])
z++;
if(z==0)
{
fault++;
if(i>m-1)
{
for(a=0;a<m;a++)
x[a]=0;
for(c=0;c<m;c++)
for(b=i;b<n;b++)
{
if(q[c]!=p[b])
x[c]++;
else
break;
}
max=x[0];l=0;
if(x[1]>max){ max=x[1];l=1;}
if(x[2]>max){ max=x[2];l=2;}
}
q[l]=p[i];
l++;
z=0;
for(k=0;k<m;k++)
printf("%d\t",q[k]);
printf("\n");
}
z=0;
}
printf("No. of page faults:%d",fault);
}
// MFT
#include<stdio.h>
main()
{
int ms,choice,size,nb,i,j,frag;
static int sz[20][2],nj,s;
int count=0;
static int jobs[20][3];
printf("enter memory space:\n");
scanf("%d",&ms);
printf("enter your choice:");
printf("\n enter \n 1.equal partition \n 2.unequal partition");
scanf("%d",&choice);
if(choice==1)
{
printf("enter size of each block:");
scanf("%d",&s);
nb=ms/s;
for(i=0;i<nb;i++)
sz[i][0]=s;
printf("total no. of blocks: %d\n",nb);
}
else
{
printf("enter no. of blocks:\n");
scanf("%d",&nb);
for(i=0;i<nb;i++)
{
printf("enter size of %d block:\n",i);
scanf("%d",&sz[i][0]);
}
}
printf("enter no. of jobs:\n");
scanf("%d",&nj);
printf("enter job info \n 1.job id \n 2.job size\n");
for(i=0;i<nj;i++)
scanf("%d%d",&jobs[i][0],&jobs[i][1]);
frag=0;
for(i=0;i<nj;i++)
{
if(jobs[i][1]<sz[i][0])
{
jobs[i][2]=2;
frag+=sz[i][0]-jobs[i][1];
count+=1;
}
}
printf("total internal fragmentation is %d\n",frag);
printf("no. of free blocks:%d\n",nb-count);
printf("the jobs which are not allocated:");
if(count==nj)
printf("0");
for(i=0;i<nj;i++)
{
if(jobs[i][2]!=2)
printf("\n job id-> %d \n job size-> %d",jobs[i][0],jobs[i][1]);
}
}
// MVT mvt.c
#include<stdio.h>
main()
{
static int jobs[20][2],flag[10],i,k,nj,nb=0,tms,ch;
printf("Enter no. of jobs:");
scanf("%d",&nj);
printf("Enter total memory space:");
scanf("%d",&tms);
printf("Enter job info:\n1.Job id\n2.Job size\n");
for(i=0;i<nj;i++)
scanf("%d%d",&jobs[i][0],&jobs[i][1]);
for(i=0;i<nj;i++)
{
if(tms>=jobs[i][1])
{
nb=nb+1;
tms=tms-jobs[i][1];
flag[i]=1;
}
}
printf("Free space after allocation is %d",tms);
printf("\nThe allocated jobs are:\n");
for(i=0;i<nj;i++)
if(flag[i]==1)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
printf("\nJobs which are not allocated are:\n");
for(i=0;i<nj;i++)
if(flag[i]==0)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
if(nb!=nj)
{
while(1)
{
printf("Enter the job id to deallocate:\n");
scanf("%d",&k);
for(i=0;i<nj;i++)
if(jobs[i][0]==k)
if(flag[i]==1)
{
tms=tms+jobs[i][1];
flag[i]=2;
printf("The deallocated job is \n%d->%d",jobs[i][0],jobs[i][1]);
}
for(i=0;i<nj;i++)
if(tms>=jobs[i][1])
if(flag[i]==0)
{
tms=tms-jobs[i][1];
flag[i]=1;
}
printf("\nThe allocated jobs are:\n");
for(i=0;i<nj;i++)
if(flag[i]==1)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
printf("Jobs which are not allocated are:");
for(i=0;i<nj;i++)
if(flag[i]==0||flag[i]==2)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
printf("\nFree space after allocating is %d",tms);
printf("\nDo you want to deallocate\n1.Yes\n2.No\n");
scanf("%d",&ch);
if(ch==2)
break;
}
}
printf("Allocated jobs are:\n");
for(i=0;i<nj;i++)
if(flag[i]==1)
printf("%d->%d\n",jobs[i][0],jobs[i][1]);
}
OS Programs
bankers algorithm
[cse2b523@localhost ~]$ vi bankers.cpp
#include<iostream>
using namespace std;
class bankalg
{
int **alloc;
int **max;
int *work;
int *avail;
int **need;
int *safe;
int *flag;
int p,r;
public:
void read();
void safe_sequence();
void request_resource();
};
void bankalg::read()
{
int i,j;
cout<<"\nEnter the total number of processes\n";
cin>>p;
cout<<"\nEnter the number of resource types\n";
cin>>r;
alloc=new int* [p];
max=new int* [p];
need=new int* [p];
avail=new int[r];
work=new int[r];
for(i=0;i<p;i++)
{
alloc[i]=new int[r];
max[i]=new int[r];
need[i]=new int[r];
}
cout<<"\nEnter the allocated resources of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>alloc[i][j];
}
cout<<"\nEnter the Maximum number of resources for each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>max[i][j];
}
cout<<"\nEnter the available resources of each type\n";
for(i=0;i<r;i++)
cin>>avail[i];
for(i=0;i<r;i++)
work[i]=avail[i];
}
void bankalg::safe_sequence()
{
int i,j;
safe=new int[p];
flag=new int[p];
for(i=0;i<p;i++)
{
flag[i]=0;
}
for(i=0;i<p;i++)
for(j=0;j<r;j++)
need[i][j]=max[i][j]-alloc[i][j];
int l=0;
for(int z=0;z<(p*p);z++)
{
for(int i=0;i<p;i++)
{ if(flag[i]==0)
{
j=0;
while(j<r)
{ if(need[i][j]<=avail[j])
{
if(j==r-1)
{ flag[i]=1;
for(int k=0;k<r;k++)
avail[k]+=alloc[i][k];
safe[l++]=i;
cout<<"\n"<<i<<"\n";
} j++;
}
else break;
}
}
}
for(int i=0;i<p;i++)
{
if(flag[i]==1)
{ if(i==r-1)
{
cout<<"\nThe safe sequence is:\n";
for(j=0;j<p;j++)
cout<<"P"<<safe[j]<<" ";
return;
}
}
}
}
cout<<"\nSystem is not in safe state\n";
}
void bankalg::request_resource()
{
int m;
int *request=new int[r];
cout<<"Enter the the new request:\nProcess which is requesting:";
cin>>m;
cout<<"Request:";
for(int i=0;i<r;i++)
cin>>request[i];
int i=0;
while(i<r)
{
if(request[i]<=need[m][i])
i++;
else
{
cout<<"Error.";
exit(1);
}
}
i=0;
while(i<r)
{
if(request[i]<avail[i])
i++;
else
break;
}
if(i==3)
{
for(int i=0;i<r;i++)
avail[i]=work[i];
for(int i=0;i<r;i++)
{
avail[i]=avail[i]-request[i];
alloc[m][i]+=request[i];
need[m][i]-=request[i];
}
safe_sequence();
}
else
cout<<"Request cannot be granted.";
}
int main()
{
int choice;
bankalg ob;
ob.read();
ob.safe_sequence();
cout<<"\nIf you want to enter a new request press 1. Else press 2.\n";
cin>>choice;
switch(choice)
{
case 1:ob.request_resource();
break;
case 2:exit(1);
}
}
Detection algorithm
#include<iostream>
using namespace std;
class bankalg
{
int **alloc;
int **request;
int *work;
int *avail;
int *safe;
int *flag;
int p,r;
public:
void read();
void safe_sequence();
void request_resource();
};
void bankalg::read()
{
int i,j;
cout<<"\nEnter the total number of processes\n";
cin>>p;
cout<<"\nEnter the number of resource types\n";
cin>>r;
alloc=new int* [p];
request=new int* [p];
avail=new int[r];
work=new int[r];
for(i=0;i<p;i++)
{
alloc[i]=new int[r];
request[i]=new int[r];
}
cout<<"\nEnter the allocated resources of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>alloc[i][j];
}
cout<<"\nEnter the request of each process\n";
for(i=0;i<p;i++)
{
cout<<"P"<<i<<":";
for(j=0;j<r;j++)
cin>>request[i][j];
}
cout<<"\nEnter the available resources of each type\n";
for(i=0;i<r;i++)
cin>>avail[i];
for(i=0;i<r;i++)
work[i]=avail[i];
}
void bankalg::safe_sequence()
{
int i,j;
safe=new int[p];
flag=new int[p];
for(i=0;i<p;i++)
{
flag[i]=0;
}
int l=0;
for(int z=0;z<(p*p);z++)
{
for(int i=0;i<p;i++)
{ if(flag[i]==0)
{
j=0;
while(j<r)
{ if(request[i][j]<=avail[j])
{
if(j==r-1)
{ flag[i]=1;
for(int k=0;k<r;k++)
avail[k]+=alloc[i][k];
safe[l++]=i;
cout<<"\n"<<i<<"\n";
} j++;
}
else break;
}
}
}
for(int i=0;i<p;i++)
{
if(flag[i]==1)
{ if(i==r-1)
{
cout<<"\nThe safe sequence is:\n";
for(j=0;j<p;j++)
cout<<"P"<<safe[j]<<" ";
return;
}
}
else break;
}
}
cout<<"\nSystem is not in safe state\n";
}
void bankalg::request_resource()
{
int *req=new int[r];
int m;
cout<<"Enter the the new request:\nProcess which is requesting:";
cin>>m;
cout<<"Request:";
for(int i=0;i<r;i++)
{
cin>>req[i];
request[m][i]+=req[i];
}
for(int i=0;i<r;i++)
avail[i]=work[i];
safe_sequence();
}
int main()
{
int choice;
bankalg ob;
ob.read();
ob.safe_sequence();
cout<<"\nIf you want to enter a new request press 1. Else press 2.\n";
cin>>choice;
switch(choice)
{
case 1:ob.request_resource();
break;
case 2:exit(1);
}
}
FCFS:
#include<iostream>
using namespace std;
class theatre
{
int a[10];
int size;
public:
void tickets();
void waitingtime();
};
void theatre::tickets()
{
cout<<"Enter number of ppl:";
cin>>size;
cout<<"Enter number of tickets required by each person:";
for(int i=0;i<size;i++)
cin>>a[i];
cout<<"Number of tickets for each person is:\n";
for(int i=0;i<size;i++)
cout<<a[i]<<"\n";
}
void theatre::waitingtime()
{
float w=0,r=0,t=0;
int i;
for(i=0;i<size-1;i++)
{
t=t+a[i];
w=w+t;
r=r+t;
}
r=r+t+a[i];
cout<<"Average waiting time is:"<<w/size;
cout<<"Average turnaround time is:"<<r/size;
}
int main()
{
theatre ob;
ob.tickets();
ob.waitingtime();
}
Priority
[cse2b523@localhost ~]$ vi priority.cpp
#include<iostream>
using namespace std;
class tkt
{
int b[20],k,n,a[20],c[20];
float awt,att,t,j;
int co,temp,temp1;
public:
void read();
void display();
void time();
};
void tkt::read()
{
cout<<"Enter the number of processes\n";
cin>>n;
cout<<"Enter the cpu burst time of each process\n";
for(int i=1;i<n+1;i++)
{
cout<<"The cpu burst time " <<i<< " process is \n";
cin>>b[i];
}
cout<<"Enter the priority of each order\n";
for(int i=1;i<n+1;i++)
{
cout<<"The priority of "<<i<<" is ";
cin>>c[i];
}
for(int i=1;i<n+1;i++)
for(int j=1;j<i;j++)
{
if(c[j]>c[i])
{
temp=b[j];
b[j]=b[i];
b[i]=temp;
temp1=c[j];
c[j]=c[i];
c[i]=temp1;
}
}
}
void tkt:: display()
{
cout<<"The process in the queue is \n";
for(int i=1;i<n+1;i++)
{
cout<<i<<" process "<< b[i] <<"cpu burst time \n";
}
}
void tkt::time()
{
co=0;
t=0;
j=0;
for(int i=1;i<=n;i++)
{
co=co+b[i];
a[i]=co;
}
for(int i=1;i<n;i++)
{
t=t+a[i];
}
awt=t/n;
cout<<"The average waiting time is "<<awt<<"\n";
for(int i=1;i<=n;i++)
{
j=j+a[i];
}
att=j/n;
cout<<"The average turn around time is "<<att;
}
int main()
{
tkt ob;
ob.read();
ob.display();
ob.time();
}
Round Robin
#include<iostream>
using namespace std;
class roundrobin
{
public:
int a[100],b[100],c[100],d[100],e[100],m,p;
void getinfo();
void calculations();
float n;
};
void roundrobin::getinfo()
{
cout<<"enter the no of processes\n";
cin>>n;
cout<<"enter each process burstime\n";
for(int i=0;i<n;i++)
{
cin>>a[i];
d[i]=a[i];
}
cout<<"enter the quantum time\n";
cin>>m;
}
void roundrobin::calculations()
{
int s=0;
for(int i=0;i<n;i++)
c[i]=0;
for(int i=0;i<n;i++)
{
if(a[i]%m==0)
s=s+a[i]/m;
else
s=s+(a[i]/m+1);
}
cout<<" the number titrations " << s <<"\n";
int i=0,j=0;
while(i<s)
{
if(j==n)
{
j=0;
}
else
{
if(a[j]==0)
j++;
else if(a[j]>m)
{
b[i++]=m;
a[j++]=a[j]-m;
}
else if(a[j]==m)
{
b[i++]=m;
int sum=0;
for(int k=0;k<i;k++)
sum=sum+b[k];
c[j]=sum-d[j];
e[j]=sum;
a[j++]=0;
}
else if(a[j]<m)
{
b[i++]=a[j];
int sum=0;
for(int k=0;k<i;k++)
sum=sum+b[k];
c[j]=sum-d[j];
e[j]=sum;
a[j++]=0;
}
}
}
cout<<"\n";
for(int i=0;i<s;i++)
cout<<b[i]<<"\t";
cout<<"\n";
float awt,att; int wt=0,tt=0;
for(int i=0;i<n;i++)
wt=wt+c[i];
awt=wt/n;
cout<<"average waiting time is:"<<awt<<"\n";
for(int i=0;i<n;i++)
tt=tt+e[i];
att=tt/n;
cout<<"\naverage turn around time is:"<<att<<"\n";
}
int main()
{
roundrobin r;
r.getinfo();
r.calculations();
}
SJF
#include<iostream>
using namespace std;
class theatre
{
int a[10];
int size;
public:
void tickets();
void sort();
void waitingtime();
};
void theatre::tickets()
{
cout<<"Enter number of ppl:";
cin>>size;
cout<<"Enter number of tickets required by each person:";
for(int i=0;i<size;i++)
cin>>a[i];
cout<<"Number of tickets for each person is:\n";
for(int i=0;i<size;i++)
cout<<a[i]<<"\n";
}
void theatre::sort()
{
for(int i=0;i<size-1;i++)
{
int small=i;
for(int j=i+1;j<size;j++)
{
if(a[j]<a[small])
small=j;
}
int t=a[small];
a[small]=a[i];
a[i]=t;
}
for(int i=0;i<size;i++)
cout<<a[i]<<"\t";
}
void theatre::waitingtime()
{
float w=0,c=size-1,t=0;
int i;
for(i=0;i<size-1;i++)
{
w=w+a[i]*c;
c--;
}
for(int i=0;i<size;i++)
t=t+a[i];
t=t+w;
cout<<"Average waiting time is:"<<w/size;
cout<<"Average turnaround time is:"<<t/size;
}
int main()
{
theatre ob;
ob.tickets();
ob.sort();
ob.waitingtime();
}
No comments:
Post a Comment