//Round Robin scheduling algorithm implementation using C++
#include"iostream.h"
#include"conio.h"
#include"string.h"

int total,i,j,n,m;
float avg;

class fcfs
{
 int bt[12],wt[12],et[12],rt,timer,count,found;
 char p[12][6];
 public:
 fcfs()
 {
  wt[0]=0;
  total=0;
  avg=0;
 }
 void input(int n);
 void apply();
 void display();
};
//program written by Mars. 20/09/2011. OS lab.

 void fcfs::input(int n)
 {
  for(i=0;i<n;i++)
  {
   cout<<"Enter process "<<i+1<<" name :";
   cin>>p[i];
   cout<<"Enter process time :";
   cin>>bt[i];
   cout<<"enter burst time";
   cin>>bt[i];
  }
 }

 void fcfs:: apply()
 {
  timer=4;
  m=n;
  wt[0]=0;
i=0;
do
{
if(bt[i]>timer)
{
rt=bt[i]-timer;
strcpy(p[n],p[i]);
bt[n]=rt;
et[i]=timer;
n++;
}
else
{
et[i]=bt[i];
}
i++;
wt[i]=wt[i-1]+et[i-1];
}
while(i<n);
count=0;
for(i=0;i<m;i++)
{
for(j=i+1;j<=n;j++)
{
if(strcmp(p[i],p[j])==0)
{
count++;
found=j;
}
}
if(found!=0)
{
wt[i]=wt[found]-(count*timer);
count=0;
found=0;
}
}
for(i=0;i<m;i++)
{
total+=wt[i];
}
avg=(float)total/m;
 }

 void fcfs::display()
 {
  cout<<"P_name P_time W_time
";

  for(i=0;i<n;i++)
  cout<<p[i]<<" "<<bt[i]<<" "<<wt[i]<<"
";

 }

void main()
{
 fcfs fcfs;
 clrscr();
 cout<<"Enter no. of processes :";
 cin>>n;
 fcfs.input(n);
 fcfs.apply();
 fcfs.display();
 cout<<"total waiting time :"<<total<<"
";

 cout<<"Average waiting Time :"<<avg;
 getch();
}


Categories: , , ,

Leave a Reply