基本情報技術者平成13年秋期 午前問13

午前問13

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

 push(a)
 push(b)
 enq(pop())
 enq(c)
 push(d)
 push(deq())
 x←pop()
  • [この問題の出題歴]
  • 基本情報技術者 H18春期 問12
  • 基本情報技術者 H26春期 問7
  • ソフトウェア開発技術者 H16春期 問10

分類

テクノロジ系 » アルゴリズムとプログラミング » データ構造

正解

解説

スタックは後入先出し、キューは先入先出しのデータ構造です。設問の手続きの実行するとスタックとキューの内容は次のように変化していきます。
  1. push(a)…aをスタックに挿入する
    13_1.gif/image-size:238×117
  2. push(b)…bをスタックに挿入する
    13_2.gif/image-size:238×117
  3. enq(pop())…スタックから取り出したデータ(b)をキューに挿入する
    13_3.gif/image-size:238×117
  4. enq(c)…cをキューに挿入する
    13_4.gif/image-size:238×117
  5. push(d)…dをスタックに挿入する
    13_5.gif/image-size:238×117
  6. push(deq())…キューから取り出したデータ(b)をスタックに挿入する
    13_6.gif/image-size:238×117
  7. x←pop()…スタックから取り出したデータ(b)をxに代入する
    13_7.gif/image-size:238×117
したがってxに代入されるデータはbになります。
© 2010-2021 基本情報技術者試験ドットコム All Rights Reserved.

Pagetop