三つのスタックA、B、Cのいずれの初期状態も [1、2、3] であるとき、再帰的に定義された関数 f() を呼び出して終了した後のBの状態はどれか。ここで、スタックが
[a1、a2、...、an-1] の状態のときにanを pushした後のスタックの状態は [a1、a2、...、an-1、an]で表す。
f(){
Aが空ならば{
何もしない。
}
そうでない場合{
Aからpopした値をCに pushする。
f() を呼び出す。
Cからpopした値をBに pushする。
}
}
ア [1、2、3、1、2、3]
イ [1、2、3、3、2、1]
ウ [3、2、1、1、2、3]
エ [3、2、1、3、2、1]
ア
スタックはLIFO (後入れ先出し) により置換するアルゴリズムである。
popはスタックからデータを取り出す操作、pushはスタックにデータを入れる操作である。
三つのスタックは以下のように遷移していく。
0-0 初期状態
A[1, 2, 3] B[1, 2, 3] C[1, 2, 3]
0-1 f()を呼び出す。
@-1 Aからpopした値をCにpushする。
A[1, 2, 3] B[1, 2, 3] C[1, 2, 3, 3]
@-2 f()を呼び出す。
A-1 Aからpopした値をCにpushする。
A[1, 2] B[1, 2, 3] C[1, 2, 3, 3, 2]
A-2 f()を呼び出す。
B-1 Aからpopした値をCにpushする。
A[1] B[1, 2, 3] C[1, 2, 3, 3, 2, 1]
B-2 f()を呼び出す。
Aが空なので何もしない
B-3 Cからpopした値をBにpushする。
A[] B[1, 2, 3, 1] C[1, 2, 3, 3, 2, 1]
A-3 Cからpopした値をBにpushする。
A[] B[1, 2, 3, 1, 2] C[1, 2, 3, 3, 2]
@-3 Cからpopした値をBにpushする。
A[] B[1, 2, 3, 1, 2, 3] C[1, 2, 3, 3]
よって、スタックBの状態は、[1, 2, 3, 1, 2, 3] となる。
問5 | 目次 | 問7 |