本文へスキップ

FUNDAMENTAL INFORMATION TECHNOLOGY ENGINEER

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

データ構造及びアルゴリズム 難しい fe_b_v90_alg_trace_114

問題

次の二ポインタ法で,和が8以下の組の数を求める。戻り値はどれか。

整数型の配列: a ← {1, 2, 3, 5, 7}
整数型: left ← 1, right ← 5, count ← 0
while (left < right)
  if (a[left] + a[right] ≦ 8)
    count ← count + (right - left)
    left ← left + 1
  else
    right ← right - 1
  endif
endwhile
return count
  1. 5
  2. 6
  3. 7
  4. 8
出典:オリジナル問題|参考範囲:試験要綱Ver.5.5 / FEシラバスVer.9.2 科目B範囲

正解と解説

正解:7

正解:7

配列は昇順なので,a[left]+a[right]が8以下なら,leftとleft+1〜rightまでの全ての組が条件を満たす。そのためcountにright-leftを一気に足す。

leftright判定count
151+7≦84
252+7>84
242+5≦86
343+5≦87

最終的にcountは7。条件を満たすたびに1だけ増やすのではない点が重要である。

選択肢の見分け方:5や6は一括加算right-leftを一部しか足していない値,8は条件を超える組まで含めた値である。整列済みであることを利用してまとめて数える。

この問題について

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

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

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

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

RELATED

関連問題