イが正解となる理由は、各実装方法における要素の追加・削除の計算量にあります。
2009年度 秋期 ネットワークスペシャリスト 午前I 問3
n個の要素x1,x2,…,xから成る連結リストに対して、新たな要素 xm+1の末尾への追加に要する時間をf(n) とし、末尾の要素x』の削除に要する時間をg(n) とする。n が非常に大きいとき、実装方法 1 と実装方法2におけるf(n)g(n)の挙動として、適切なものはどれか。〔実装方法1〕先頭のセルを指すポインタ型の変数 front だけをもつ。〔実装方法2〕先頭のセルを指すポインタ型の変数 front と、末尾のセルのを指すポインタ型の変数rear を併せもつ。
選択肢
解説
結論 → 詳細 → 補足 の 3 層構成
展開閉じる
解説
結論 → 詳細 → 補足 の 3 層構成
実装方法1は、先頭のセルを指すポインタ front のみを持つため、末尾への要素追加や末尾要素の削除には、リストの先頭から末尾までを順番にたどる必要があります。これはリストの要素数nに比例した時間がかかり、計算量はO(n)となります。したがって、f(n)もg(n)もほぼnに比例します。
実装方法2は、先頭のポインタ front に加えて、末尾のセルを指すポインタ rear を持ちます。このrearポインタを利用することで、末尾への要素追加は直接末尾のセルに新しい要素を連結できるため、定数時間O(1)で完了します。末尾要素の削除も、rearポインタから一つ前の要素をたどることで、これも定数時間O(1)で実現できます。したがって、f(n)はほぼ1に比例し、g(n)もほぼ1に比例します。
アは、実装方法2における末尾要素の削除時間がnに比例すると誤っています。実装方法2ではrearポインタがあるため、末尾削除は定数時間で可能です。
ウは、実装方法1における末尾への要素追加時間が1に比例すると誤っています。実装方法1では末尾への追加はリストの走査が必要なため、nに比例します。
エは、実装方法1における末尾への要素追加時間と、実装方法2における末尾要素の削除時間が共にnに比例すると誤っています。実装方法2ではrearポインタにより末尾操作が効率化されます。
この解説は AI 生成です(詳細)
解説テキストは Google Gemini に IPA 公式の問題文・公式解答を入力して生成しました。 人間によるレビューを行ったものと、未レビューのものが混在します。
AI は事実誤認・選択肢の取り違え・最新法令の反映漏れ等を含む可能性があります。 重要な判断は必ず IPA 公式 PDF または最新の参考書でご確認ください。
解説の検証プロセス・誤り報告フローは 運営透明性レポートで公開しています。
分野「基礎理論」の学習ポイント
この問題の理解を「分野全体の力」に広げるための足がかり
- 何が問われるか
- 2進数・論理演算・確率・統計など、IT全般の土台となる数学・離散構造の理解度。
- 学習の進め方
- 公式の暗記ではなく、ビット表現や真理値表を「手で書ける」状態を作る。例題を3パターン以上手で解いて感覚化する。
- 関連キーワード
- 2進数論理演算シフト演算誤差確率情報量
この問題を AI と深掘りする
用語解説・選択肢分析・類題生成をその場で対話。クイズモードでは解答→解説がゼロ遷移。
共有
ショート動画
関連する問題
基礎理論 の他の問題
- ネットワークスペシャリスト2009年度 秋期 午前I 問12進数の表現で、2の補数を使用する理由はどれか。
- ネットワークスペシャリスト2009年度 秋期 午前I 問62台のプリンタがあり、それぞれの稼働率が0.7と0.6である。この2台のいずれか一方が稼働していて、他方が故障している確率は幾らか。ここで、2台のプリンタの稼働状態は独立であり、プリンタ以外の要因は考慮しないものとする。
- ネットワークスペシャリスト2009年度 秋期 午前I 問8図の論理回路において, S=1, R=1, X=0, Y=1 のとき、S をいったん0にした後、再び1に戻した。この操作を行った後のX、Yの値はどれか。
- ネットワークスペシャリスト2010年度 秋期 午前I 問1後置表記法(逆ポーランド表記法)では、例えば、式 Y=(A-B)×C を YAB-Cx=と表現する。 次の式を後置表記法で表現したものはどれか。 Y=(A+B)×(C-(D÷E))
- ネットワークスペシャリスト2010年度 秋期 午前I 問2a, b, c, dの4文字からなるメッセージを符号化してビット列にする方法として表のア〜エの4通りを考えた。この表は a,b,c,dの各1文字を符号化するときのビット列を表している。メッセージ中での a, b, c, dの出現頻度は,それぞれ 50%, 30%, 10%, 10…