Analise o seguinte trecho de código em Java e escolha a opção que mostra o que o programa irá imprimir na tela:
Pilha P = new Pilha();
for(int i=0; i<=10; i=i+2) {
P.push(i+1);
}
P.push(P.top());
P.push(P.pop());
while(!P.isEmpty()) {
System.out.print(P.pop() + ", ");
}
Respostas
Irá 'empilhar' o seguinte:
i varia de 0 a 10, de 2 em 2, e na pilha 'empilha' o i+1, ou seja, de 1 a 11, de 2 em 2, portanto:
{1, 3, 5, 7, 9, 11}
Não conheço o método top() mas imaginando que seja o mesmo que peek(), ele só 'observa' o elemento que está no topo, sem desempilhar.
Então, empilhando o topo:
{1, 3, 5, 7, 9, 11, 11}
Agora, desempilha o topo... e empilha novamente:
{1,3,5,7,9,11,11}
Agora, imprime até esvaziar a pilha:
11, 11, 9, 7, 5, 3, 1
Espero ter ajudado!
A pilha é impressa da direita para a esquerda, pois os elementos removidos são os últimos inseridos, resultando em 11, 11, 9, 7, 5, 3, 1.
Pilha
Uma pilha é uma estrutra de dados onde os elementos são acessados apenas pelo topo, onde o último elemento inserido é o primeiro a ser retirado.
Analisando a sequência do código, temos a seguinte pilha sendo formada (onde a pilha cresce da esquerda para a direita):
1
1 3
1 3 5
1 3 5 7
1 3 5 7 9
1 3 5 7 9 11
Após, a função top() retorna o elemento em seu topo, que é 11, tornando a pilha:
1 3 5 7 9 11 11
A função pop() retorna o elemento no topo e o remove, tornando a pilha:
1 3 5 7 9 11 11
Assim, a pilha é impressa da direita para a esquerda, pois os elementos removidos são os últimos inseridos, resultando em 11, 11, 9, 7, 5, 3, 1.
Para aprender mais sobre estruturas de dados, acesse:
https://brainly.com.br/tarefa/26918121
#SPJ2