Wednesday, April 20, 2011

Infix expression to prefix expression conversion

/* program on conversion of infix to prefix expression */

#include "stdio.h"
#include "stdlib.h"
#include "string.h"

#define OPT 0
#define OPND 1
#define LP 2
#define RP 3

char infix[100], prefix[100]; /* global variables declare here */

struct stack
{
char info;
struct stack *next;
} *stk;


/* main function here */

int main(void)
{
clrscr();
printf("\nEnter a infix expression : ");
fflush(stdin);
gets(infix);
intopre();
printf("\nPrefix expression is : %s", prefix);
getch();
return 0;
}


/* push function here */

push(struct stack *s, char n)
{
struct stack *temp;
temp = (struct stack *)malloc(sizeof(struct stack));
temp->info = n;
temp->next = s;
stk = temp;
}

/* Pop function here */

char pop(struct stack *s)
{
char ch;
if(s!=NULL)
{
ch = s->info;
stk = s->next;
free(s);
}
return ch;
}
/* ---- get character type here wheather operator or operand ----- */
int gettype(char ch)
{
if(ch=='+'|| ch == '-' || ch == '*' || ch == '/' || ch == '%')
return OPT;
else if(ch == '(')
return LP;
else if(ch == ')')
return RP;
else
return OPND;
}

/* --- get precedence of operator ------ */
prec(char op)
{
switch(op)
{
case ')':
case '(': return 0;
case '+':
case '-': return 1;
case '*':
case '/':
case '%': return 2;
case '^': return 3;
}
}


/* convert infix to prefix expression ---- */
intopre()
{
int i,p, type, pr;
char ch, op;
for(i=0; infix[i]!='\0';i++);

for(i=i-1, p=0; i>=0;i--)
{
ch = infix[i];
type = gettype(ch);
switch(type)
{
case OPND: prefix[p++] = ch;
break;
case RP: push(stk, ch); break;
case OPT: pr = prec(ch);
while(stk!=NULL&& prinfo))
prefix[p++] = pop(stk);
push(stk, ch);
break;
case LP: while(stk!=NULL && (op = pop(stk))!=')')
prefix[p++] = op;
break;
}
}

while(stk!=NULL)
prefix[p++] = pop(stk);
prefix[p] = '\0';
strrev(prefix);
}

0 comments:

Post a Comment

Related Posts Plugin for WordPress, Blogger...

Share

Twitter Delicious Facebook Digg Stumbleupon Favorites