平成18年春期試験問題 午前問12

空の状態のキューとスタックの二つのデータ構造がある。次の手続を順に実行した場合,変数xに代入されるデータはどれか。ここで,
 データyをスタックに挿入することを push(y),
 スタックからデータを取り出すことを pop(),
 データyをキューに挿入することを enq(y),
 キューからデータを取り出すことを deq(),
とそれぞれ表す。


 push(a)
 push(b)
 enq(pop())
 enq(c)
 push(d)
 push(deq())
 x ← pop()

  • a
  • b
  • c
  • d
正解 問題へ
分野 :テクノロジ系
中分類:アルゴリズムとプログラミング
小分類:データ構造
解説
スタックは後入先出し、キューは先入先出しのデータ構造です。設問の手続きの実行するとスタックとキューの内容は次のように変化していきます。
  1. push(a)…aをスタックに挿入する
    12_1.png
  2. push(b)…bをスタックに挿入する
    12_2.png
  3. enq(pop())…スタックから取り出したデータ(b)をキューに挿入する
    12_3.png
  4. enq(c)…cをキューに挿入する
    12_4.png
  5. push(d)…dをスタックに挿入する
    12_5.png
  6. push(deq())…キューから取り出したデータ(b)をスタックに挿入する
    12_6.png
  7. x←pop()…スタックから取り出したデータ(b)をxに代入する
    12_7.png
したがってxに代入されるデータはbになります。

この問題の出題歴


Pagetop