123 Eng

Engineering the engineers™


Latest Jobs   Forum Map

 


Home
Source Codes
Engineering Colleges

Training  Reports
Seminar Reports
Placement Papers

Forums

   Computer Science / IT
   Electronics
   Electrical
   Mechanical
   Chemical
   Civil

   CAT / MBA

   GMAT / Foreign MBA
Latest Jobs

Engineering Jobs / Technical Jobs
Management Jobs

Sitemap
Terms of use

Displaying  Source Code(s)  
 

 
Graphical Representation of Queue

--------------------------------------------------------------------------------

Description : Graphical Representation of Queue


// Queue //
// Rakesh Juyal//

#include <graphics.h>
#include <conio.h>
#include <stdio.h>
#define MAX 20


struct Queue
{
int st[MAX];
};

void Insert(struct Queue *My,int val);
void Delete(struct Queue *My);
void DISPLAY(struct Queue My);
void main()
{
char ch;
int num,tot,i;

struct Queue MyQ;
MyQ.st[0]=2;
MyQ.st[1]=2;

Menu:
clrscr();
printf("



***********************<BR>);
printf(" MENU QU<BR>);
printf(" ************************<BR>);
printf("
1. Insert");
printf("
2. Delete");
printf("
3. Display");
printf("
4. Exit");
printf("

Choose Your Destiny:- ");

ch=getche();

switch(ch)
{
case '1':
printf("
How Many Element To Insert:- ");
scanf("%d",&tot);
for(i=0;i<tot;i++)
{
printf(" Enter the number to Insert:- ");
scanf("%d",&num);
Insert(&MyQ,num);
}
printf("
Inserted . . .");
getch();
goto Menu;
case '2':
printf("
How Many Element To Delete:- ");
scanf("%d",&tot);
for(i=0;i<tot;i++)
{
Delete(&MyQ);
}
getch();
goto Menu;
case '3':
DISPLAY(MyQ);
goto Menu;
case '4':
printf("

Exiting . . .");
getch();
break;
}
closegraph();
}

/*******************************************
Function: PUSH
Discription: Insert an Element in Stack
*******************************************/

void Insert(struct Queue *My,int val)
{
if(My->st[1]>=MAX+1)
{
printf("

Already Full:-");
getch();
return;
}

My->st[My->st[1]]=val;
My->st[1]=My->st[1]+1;
}

/*******************************************
Function: POP
Discription: POP an Element in Stack
*******************************************/



void Delete(struct Queue *My)
{
if(My->st[0]==My->st[1])
{
printf("

U SUCK:- Nothing To Delete:-");
getch();
return;
}
My->st[0]=My->st[0]+1;
printf("
One Element Deleted . . .");
}

void DISPLAY(struct Queue My)
{
int g=DETECT,d,i;
int j=400;
char str[10];

if(My.st[0]>=My.st[1])
{
printf("

Hey Wicked, Atleast PUSH One Item");
getch();
return;
}

initgraph(&g,&d,"c:\tc\bgi");

setbkcolor(BLUE);
outtextxy(10,10," Press Any Key...");
getch();

setfillstyle(11,12);
for(i=2;i<20;i++)
{
setcolor(RED);
bar(200,j,400,j-20);
rectangle(200,j,400,j-20);
j=j-20;
}
j=400;
for(i=2;i<My.st[0];i++)
{
setcolor(RED);
rectangle(200,j,400,j-20);
j=j-20;
}
setfillstyle(1,CYAN);
for (i=My.st[0];i<My.st[1];i++)
{
setcolor(GREEN);
delay(200);
bar(200,j,400,j-20);
rectangle(200,j,400,j-20);
sprintf(str,"%d",My.st[i]);
setcolor(RED);
outtextxy(280,j-10,str);
j=j-20;
}
j=390;
for(i=2;i<My.st[0];i++)
j=j-20;
outtextxy(410,j," <- Rear Pointer");

j=390;
for(i=2;i<My.st[1];i++)
j=j-20;
outtextxy(410,j," <- Front Pointer");

getch();
restorecrtmode();
}



 

 

 

Contribute content or training reports / feedback / Comments
job placement papers
All rights reserved © copyright 123ENG