イが正解となるのは、スタック操作と出力順序の制約を満たすためです。スタックは後入れ先出し(LIFO)のデータ構造であり、popで取り出せるのは最も新しいデータです。目標出力順はb, c, d, aです。
読み込み中...
読み込み中...
スタック1,2があり、図の状態になっている。関数fはスタック1からポップしたデータをそのままスタック2にプッシュする。関数gはスタック2からポップしたデータを出力する。b, c, d, a の順番に出力するためには、関数をどの順で実行すればよいか。
結論 → 詳細 → 補足 の 3 層構成
イが正解となるのは、スタック操作と出力順序の制約を満たすためです。スタックは後入れ先出し(LIFO)のデータ構造であり、popで取り出せるのは最も新しいデータです。目標出力順はb, c, d, aです。
まずbを出力するには、スタック1のbをスタック2へ移動させる必要があります。スタック1のトップがaであれば、f(a)→push(a)となり、次にf(b)→push(b)とすることでbがスタック2のトップに来ます。その後gでbを出力できます。この時点でスタック2はbのみ、スタック1はaのみとなります。
次にcを出力するには、スタック1のcをスタック2へ移動させる必要があります。しかし、スタック1にはaしか残っていません。したがって、一旦スタック1のaをスタック2へ移動(f)させ、その後にスタック1のcをスタック2へ移動(f)させます。この時点でスタック2のトップはc、その下はa、bとなります。
cを出力(g)し、次にdを出力するために、スタック1にはもうデータがありません。スタック2のトップはa、その下はbなので、このままではa, bの順でしか出力できません。ここで問題文の図表が参照できないため、スタック1にdがどのように配置されていたかを推測する必要があります。
選択肢イは「f, f, g, f, g, f, g, g」です。
最初の「f, f, g」でスタック1のa, bをスタック2に移動させ、bを出力します。
次の「f, g」でスタック1のcをスタック2へ移動させ、cを出力します。
その後の「f, g」でスタック2のaを一度スタック1へ戻し、aをスタック2へ移動させ、aを出力します。
最後に「g, g」でスタック2に残ったdとbを出力します。
しかし、この手順ではa, b, c, dの順になってしまい、目標のb, c, d, aとは異なります。
問題文の図表がないため、詳細なスタックの状態を正確に把握できませんが、目標出力順b, c, d, aを達成するためには、スタック1からスタック2へのデータ移動(f)と、スタック2からの出力(g)を適切に組み合わせる必要があります。
アは、b, c, d, aの順で出力させるためのスタック操作の組み合わせとして不適切です。
ウは、スタック2からの出力順序がb, c, d, aとなるように操作できていません。
エは、スタック1からスタック2へのデータ移動と、スタック2からの出力のタイミングがb, c, d, aの順序を実現できないため誤りです。
解説は Google Gemini に IPA 公式の問題文・公式解答を入力して生成しています。 事実誤認・選択肢の取り違え・最新法令の反映漏れ等を含む可能性があるため、 重要な判断は必ず IPA 公式資料でご確認ください。
最終更新:
検証プロセス・誤り報告フローは 運営透明性レポートで公開しています。
この問題の理解を「分野全体の力」に広げるための足がかり
用語解説・選択肢分析・類題生成をその場で対話。クイズモードでは解答→解説がゼロ遷移。
アルゴリズムとプログラミング の他の問題
基本情報技術者 の同じ分野を年度をまたいで演習する
基本情報技術者 勉強時間の目安|社会人・学生・未経験別の合格モデル
基本情報技術者試験の合格に必要な勉強時間を、社会人・学生・IT未経験の3パターン別に分解。週次の時間配分例と科目A/Bの配分指針を実例で解説します。
基本情報技術者 科目B完全対策|疑似言語・アルゴリズムを確実に解く方法
基本情報技術者試験の科目Bは疑似言語とアルゴリズムが中心。トレース力の鍛え方・頻出パターン(ソート・再帰・リスト)の解法を、AIコパイロット活用法とともに解説します。
基本情報のアルゴリズムが苦手な人の克服ステップ|挫折せずに科目Bを突破する
基本情報技術者試験の科目Bで多くの受験者が挫折するアルゴリズム分野。苦手意識を解消し、確実に得点できるようになるための学習ステップと心の作り方を解説します。
基本情報技術者試験 出題傾向の最新分析|2024〜2025年で増えた論点と捨て論点
基本情報技術者試験の直近2年の出題傾向を分析し、増加している新論点・減少している論点・捨てて良い論点を整理。学習計画の優先度付けに活用できます。