poj3295 Tautology , 计算表达式的值

给你一个表达式,其包含一些0,1变量和一些逻辑运算法,让你判断其是否为永真式。


计算表达式的常用两种方法:1、递归; 2、利用栈。


code(递归实现)

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <string>
using namespace std;
char str[2000];
int pos;
bool calc(int bit)
{
    pos++;
    switch(str[pos])
    {
        case 'p': return (bit)&1;
        case 'q': return (bit>>1)&1;
        case 'r': return (bit>>2)&1;
        case 's': return (bit>>3)&1;
        case 't': return (bit>>4)&1;
        case 'K': return calc(bit) &calc(bit);
        case 'A': return calc(bit) | calc(bit);
        case 'N': return !calc(bit);
        case 'C': return (!calc(bit)) | calc(bit);
        case 'E': return calc(bit) == calc(bit);
        default:;
    }
}
int main()
{
    int bit;
    bool mark;
    while(~scanf("%s", str) && str[0]!='0')
    {
        mark = true;
        for(bit=0; bit<32; ++bit)
        {
            pos = -1;
            if( !calc(bit) )
            {
                mark = false;
                break;
            }
        }
        if(mark) printf("tautology");
        else printf("not");
    }
    return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值