Jump to content

Notação Polonesa Reversa


usermanero

Recommended Posts

usermanero

Olá,

Tenho um problema sobre notação polonesa reversa. Ex:

a+b = ab+

(a+c)*b = ac+b*

Só que no meu caso, não vou ter os operadores, e devo descobri-los. Ex:

22? = 4              (respostas: 2+2 e 2*2)

Por motivos de simplificação, apenas os operadores + e * serão utilizados. Nesse caso, pensei em criar uma pilha para os operandos e quando achar o simbolo ?, desempilhar dois operandos e fazer a operação (+ ou *). Minha maior duvida aqui é em relação a como fazer todas as possíveis operações de forma eficiente. Teria alguma forma prévia de saber quando deverei somar e quando deverei multiplicar? Pois, quando tenho uma expressão maior, fica cada vez mais difícil testar todas as possibilidades. Alguma sugestão sobre como testar essas possibilidades?

Link to post
Share on other sites
HappyHippyHippo

não

uma árvore de possibilidades. o que quero dizer é que a maneira mais simples é a força bruta e testar tudo, e para isso a criação de uma árvore e percorrer-la é uma solução fácil de implementar

nota : "criar" e percorrer essa árvore não necessita obgratoriamente de alocação de uma árvore em memória

IRC : sim, é algo que ainda existe >> #p@p
Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.