本文へスキップ

FE SUBJECT B

基本情報技術者 科目Bの問題解説

プログラムの基本要素 標準 fe_b_v89_alg_blank_007

問題

文字列 s="(())()" に対して、次の手続 maxDepth(s) を実行したときの戻り値はどれか。

○整数型: maxDepth(文字列型: s)
  整数型: i, depth ← 0, max ← 0
  for (i を 1 から sの文字数 まで 1 ずつ増やす)
    if (sのi文字目 = "(")
      depth ← depth + 1
      if (depth > max)
        max ← depth
      endif
    else
      depth ← depth - 1
    endif
  endfor
  return max
  1. 1
  2. 2
  3. 3
  4. 0
出典:オリジナル問題|参考範囲:試験要綱Ver.5.5 / FEシラバスVer.9.2 科目B範囲

正解と解説

正解:2

正解:2

括弧の深さは、開き括弧で1増え、閉じ括弧で1減るスタックの積み上がりとして考える。ここでは実際に配列スタックを使っていないが、depth がスタックに積まれている開き括弧の数を表す。

(())()では、2文字目を読んだ時点で depth が2になり、これが最大である。その後は閉じ括弧で0に戻り、最後の()では深さ1までしか増えない。

文字depthmax
(11
(22
)12
)02
(12
)02

この問題について

出典:オリジナル問題|参考範囲:試験要綱Ver.5.5 / FEシラバスVer.9.2 科目B範囲

公開問題・サンプル問題の形式、擬似言語記法、アルゴリズム読解・トレース・空欄補充・セキュリティ事例判断の傾向を参考にした独自問題です。本文・数値・選択肢は新規作成しています。

公式試験問題、公開問題、市販教材、外部問題サイトの問題文を転載・改題したものではありません。

参考範囲: 2026年度現行科目B・シラバスVer.9.x参考

RELATED

関連問題