edited by
24,127 views
22 votes
22 votes

What is the minimum number of stacks of size $n$ required to implement a queue of size $n$?

  1. One
  2. Two
  3. Three
  4. Four
edited by

7 Answers

Best answer
36 votes
36 votes

A queue can be implemented using two stacks.

Let queue be represented as " $q$ "
and stacks used to implement $q$ be "stack1" and "stack2".

$q$ can be implemented in two ways:

Method 1 (By making EnQueue operation costly)

This method makes sure that newly entered element is always at the bottom of stack 1, so that deQueue operation just pops from stack1. To put the element at top of stack1, stack2 is used.

$enQueue(q, x)$

  1. While stack1 is not empty, push everything from stack1 to stack2.
  2. Push $x$ to stack1 (assuming size of stacks is unlimited).
  3. Push everything back to stack1.

$dnQueue(q)$

  1. If stack1 is empty then error
  2. Pop an item from stack1 and return it


Method 2 (By making deQueue operation costly)

In this method, in en-queue operation, the new element is entered at the top of stack1. In de-queue operation, if stack2 is empty then all the elements are moved to stack2 and finally top of stack2 is returned.
$enQueue(q,  x)$

  1. Push $x$ to stack1 (assuming size of stacks is unlimited).

$deQueue(q)$

  1. If both stacks are empty then error.
  2. If stack2 is empty
    While stack1 is not empty, push everything from stack1 to stack2.
  3. Pop the element from stack2 and return it.

Correct Answer: $B$

edited by
Answer:

Related questions

25 votes
25 votes
2 answers
2