您的位置:首页 > 其它

POJ 2106 Boolean Expressions (栈,位运算)

2013-11-13 18:28 375 查看
跟四则混合运算一个算法

建两个栈,一个保存操作符,一个保存操作数

根据操作符的优先级给操作符编号,最低优先级的数字最大(也可以反过来,随便玩),然后当操作符入栈的时候,如果栈顶数字比他大,则执行栈顶操作符直到栈为空或栈顶小于等于入栈操作符。

最后别忘了完结的时候执行完栈内操作符。

#include <stdio.h>

void execute(char mode,char *stack,int *pointer)
{
switch(mode)
{
case 3:
stack[*pointer-1]^=1;break;
case 2:
stack[*pointer-2]=stack[*pointer-1]&stack[*pointer-2];--*pointer;break;
case 1:
stack[*pointer-2]=stack[*pointer-1]|stack[*pointer-2];--*pointer;break;
}
}

int main()
{
char tmp[101],stack1[101],stack2[101];
int i=0,s1=0,s2=0,count=1;
while(NULL != gets(tmp))
{
i=0,s1=0,s2=0;
while(' '==tmp[i])
{
++i;
}
while(0 != tmp[i])
{
switch(tmp[i])
{
case 'V':
stack2[s2++]=1;break;
case 'F':
stack2[s2++]=0;break;
case ')':
while(stack1[--s1]!=0)
{
execute(stack1[s1],stack2,&s2);
}break;
case '!':
stack1[s1++]=3;break;
case '&':
while(stack1[s1-1]>2)
{
execute(stack1[--s1],stack2,&s2);
}
stack1[s1++]=2;break;
case '|':
while(stack1[s1-1]>1)
{
execute(stack1[--s1],stack2,&s2);
}
stack1[s1++]=1;break;
case '(':
stack1[s1++]=0;
}
++i;
while(0 != tmp[i] && ' '==tmp[i])
{
++i;
}
}
while(0 != s1)
{
execute(stack1[--s1],stack2,&s2);
}
printf("Expression %d: %c\n",count++,0 == stack2[0]?'F':'V');
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: