uva565 Pizza Anyone?

这道题纯属暴搜,我是在poj交的

中间按位运算符的优先级搞错了一次

优先级

运算符

名称或含义

使用形式

结合方向

说明

1

[]

数组下标

数组名[常量表达式]

左到右

 

()

圆括号

(表达式)/函数名(形参表)

 

.

成员选择(对象)

对象.成员名

 

->

成员选择(指针)

对象指针->成员名

 

2

-

负号运算符

-表达式

右到左

单目运算符

(类型)

强制类型转换

(数据类型)表达式

 

++

自增运算符

++变量名/变量名++

单目运算符

--

自减运算符

--变量名/变量名--

单目运算符

*

取值运算符

*指针变量

单目运算符

&

取地址运算符

&变量名

单目运算符

!

逻辑非运算符

!表达式

单目运算符

~

按位取反运算符

~表达式

单目运算符

sizeof

长度运算符

sizeof(表达式)

 

3

/

表达式/表达式

左到右

双目运算符

*

表达式*表达式

双目运算符

%

余数(取模)

整型表达式/整型表达式

双目运算符

4

+

表达式+表达式

左到右

双目运算符

-

表达式-表达式

双目运算符

5

<<

左移

变量<<表达式

左到右

双目运算符

>>

右移

变量>>表达式

双目运算符

6

>

大于

表达式>表达式

左到右

双目运算符

>=

大于等于

表达式>=表达式

双目运算符

<

小于

表达式<表达式

双目运算符

<=

小于等于

表达式<=表达式

双目运算符

7

==

等于

表达式==表达式

左到右

双目运算符

!=

不等于

表达式!= 表达式

双目运算符

8

&

按位与

表达式&表达式

左到右

双目运算符

9

^

按位异或

表达式^表达式

左到右

双目运算符

10

|

按位或

表达式|表达式

左到右

双目运算符

11

&&

逻辑与

表达式&&表达式

左到右

双目运算符

12

||

逻辑或

表达式||表达式

左到右

双目运算符

13

?:

条件运算符

表达式1? 表达式2: 表达式3

右到左

三目运算符

14

=

赋值运算符

变量=表达式

右到左

 

/=

除后赋值

变量/=表达式

 

*=

乘后赋值

变量*=表达式

 

%=

取模后赋值

变量%=表达式

 

+=

加后赋值

变量+=表达式

 

-=

减后赋值

变量-=表达式

 

<<=

左移后赋值

变量<<=表达式

 

>>=

右移后赋值

变量>>=表达式

 

&=

按位与后赋值

变量&=表达式

 

^=

按位异或后赋值

变量^=表达式

 

|=

按位或后赋值

变量|=表达式

 

15

,

逗号运算符

表达式,表达式,…

左到右

从左向右顺序运算



#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
using namespace std;

int command[20][105],top[100],ans[100],commands,kind,ok,error;
char input[105];

void init()
{
    int i,j;
    for(i=0;input[i]!=';';i+=2)
    {
        if(input[i]=='+')
        {
            if(command[commands-1][input[i+1]]==-1)
                 error=1;
            command[commands-1][input[i+1]]=1;
        }
        else if(input[i]=='-')
        {
            if(command[commands-1][input[i+1]]==1)
                error=1;
           command[commands-1][input[i+1]]=-1;
        }

    }
}

int judge()
{
    int i,j,flag;
    for(i=0;i<commands;i++)
    {
        flag=0;
        for(j='A';j<='P';j++)
        {
            if(command[i][j]==1)
            {
                if(kind&(1<<(j-'A')))
                {
                    flag=1;
                    break;
                }
            }
            else if(command[i][j]==-1)
            {
                if((kind&(1<<(j-'A')))==0)//按位运算符级别低
                {
                    flag=1;
                    break;
                }
            }
        }
        if(flag==0)
            return 0;
    }
    return 1;
}

int main()
{
    int i,j,flag;
    while(1)
    {
        memset(command,0,8400);
        commands=ok=error=0;
        while(flag=scanf("%s",input))
        {
            if(flag==-1)
            goto end;
            if(input[0]=='.')
                break;
            commands++;
            init();
        }
        if(error==1)
        {
            printf("No pizza can satisfy these requests.\n");
            continue;
        }
        for(kind=0;kind<65536;kind++)
        {
            if(judge())
            {
                //printf("%d",kind);
                printf("Toppings: ");
                for(i='A';i<='P';i++)
                    if(kind&(1<<(i-'A')))
                        printf("%c",i);
                printf("\n");
                ok=1;
                break;
            }
        }
        //dfs('A');
        if(ok==0)
            printf("No pizza can satisfy these requests.\n");
        /*for(i=0;i<commands;i++)
        {
            for(j=65;j<=90;j++)
                printf("%d",command[i][j]);
            puts("");
        }*/
    }
    end:;
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值