線形リストをたどる回数と計算量について

Sato39さん  
(No.1)
線形リストの問題に関する質問です。

[基本:平成27年秋期  午前  問5] 
ポインタを用いた線形リストの特徴のうち,適切なものはどれか。
1.先頭の要素を根としたn分木で,先頭以外の要素は全て先頭の要素の子である。
2.配列を用いた場合と比較して,2分探索を効率的に行うことが可能である。
3.ポインタから次の要素を求めるためにハッシュ関数を用いる。
4.ポインタによって指定されている要素の後ろに,新たな要素を追加する計算量は,要素の個数や位置によらず一定である。
答:4

ところが、別の問題では、

[応用:令和元年秋期 午前問6] 
先頭ポインタと末尾ポインタをもち,多くのデータがポインタでつながった単方向の線形リストの処理のうち,先頭ポインタ,末尾ポインタ又は各データのポインタをたどる回数が最も多いものはどれか。ここで,単方向のリストは先頭ポインタからつながっているものとし,追加するデータはポインタをたどらなくても参照できるものとする。
1. 先頭にデータを追加する処理
2. 先頭のデータを削除する処理
3. 末尾にデータを追加する処理
4. 末尾のデータを削除する処理
答:4

この2つの問題は、矛盾してるように思えるのです。
上の問題では、「新たな要素を追加する計算量は,要素の個数や位置によらず  ”一定である”」が正解であるのに、下の問題では、「ポインタをたどる回数が最も多いもの」を訊いているのです。上の問題では、"一定である"  が正解なのに、下の問題では、一定でないことを前提にして”回数が最も多いもの”を聞いているのです。これは一体どういうことなのでしょうか。

おわかりになる方、教えていただけると大変助かります。宜しくお願いします。
2023.05.19 19:20
まーぼさん 
FE シルバーマイスター
(No.2)
結論から言うと矛盾していないです。

上の問題は、

“ポインタによって指定されている要素”の後ろに,新たな要素を追加する計算量は,要素の個数や位置によらず一定である

とあるので、ポインタによって指定されていない要素の後ろに追加する計算量は一定であるかは書かれていません。また、削除に関しては全く述べられていません。

ですので、下の問題で「ポインタによって指定されている要素の後ろに,新たな要素を追加する計算量は,要素の個数や位置によらず一定である。」という性質について述べられているのは

1. 先頭にデータを追加する処理

だけですね。先頭ポインタが与えられ、先頭ポインタが追加するデータを指すようにするだけですので。2,3,4については上記の性質の前提条件を満たしていません。
2023.05.19 19:57
Sato39さん  
(No.3)
早速ご回答くださりありがとうございます。大変助かりました。
「ポインタによって指定されている」=「たどった後」という発想をすることができずに延々と悩み、この2問によってリストの仕組みが全くわからないようになり半日が過ぎ、ここで質問させていただきました。
こんなことがわからないのは自分だけで誰の役にも立たないかも知れませんが、もしかすると同じことを疑問に思う方もいらっしゃるかもしれないので追記させていただきますと、この2問を理解するのに「ポインタによって指定されている要素の削除自体は一定の計算量で行える」ということも併せて知る必要がありましたのでこのコメントに残しておきます。
2023.05.19 21:19
電タックさん 
FE ブロンズマイスター
(No.4)
みなさんの厳密な問題読み込みにびっくりしています・・・

線形リストに要素を追加する操作は以下になると思います。
1.先頭要素から対象の箇所まで探し続ける。
2.対象箇所で何かを行う。
3.対象箇所の変更による前要素の処理。
※2と3は場合によっては無いかもしれませんが

前者は、1の処理を考えてないで(ポインタによって指定されている要素の後ろに、と既に1は処理済みの上で)2と3について言っていて
後者は、1・2・3すべてに対しての参照回数で最大になるのは?と聞いているところの違いだと思ってます。

ITパスポートの試験でもそうでしたが、最初は用語の概略を知っているレベルの問題も、後発の問題ではより多角的な視点で問われることがあると思ってますのでその違いかなと思います。
2023.05.19 22:02
jjon-comさん 
FE ゴールドマイスター
(No.5)
> 「ポインタによって指定されている要素の削除自体は一定の計算量で行える」
>(スレ主さんによる回答No.3)

いいえ、間違っています。
応用情報ドットコムの解説でも、そうは書かれていないです。

ポインタによって指定されている要素の後ろに新たな要素を追加する、のであれば、即座に可能です。
ポインタが指す要素Xの後ろに新要素を追加する処理は「要素X内の次ポインタ」の書き換えで実現できるので。

( →[大崎]→[品川]→[田町]→ という線形リストにおいて、ポインタが[品川]を指している場合、
[品川]~[田町]間に [高輪GW] を追加する処理は、[品川]内の次ポインタを[高輪GW]行きに書き換えるだけで即座に(一定回数で)実現できます)

それに対して。

ポインタによって指定されている要素の削除は、即座にはできません。
ポインタが指す要素Xを削除する処理は「【要素Xを指す要素】内の次ポインタ」の書き換えなので。

( →[大崎]→[品川]→[田町]→ という線形リストにおいて、ポインタが[品川]を指している場合、
[品川]を削除するためには[品川]を変更するのでなく、[大崎]内の次ポインタを[田町]行きに書き換えねばなりません。しかし [大崎]→[品川] は単方向の線形リストなので、[品川]を指しているポインタは[大崎]にさかのぼることができません。結局、線形リストの先頭から順に[大崎]まで進むことでようやく[品川]の削除が可能になります。つまり即座に(一定回数で)は実現できません)
2023.05.19 23:55
Sato39さん  
(No.6)
jjon-comさん、間違いを指摘して下さりありがとうございます。
[大崎]内の次ポインタを[田町]行きに書き換える時の司令は、以下のような感じという理解で合ってますか?
1.品川を削除せよ
2.「単方向なんで次ポイントしか持ってないよ。後ろが誰だかわからないんだ」by品川
3.了解。1から辿っておまえ(品川)の後ろを特定する
4.品川の後ろが特定できたぞ。大崎だ。品川、次ポイント(田町)を大崎に渡せ。
2023.05.20 01:07
Sato39さん  
(No.7)
電タックさん、分かりやすくまとめて下さりありがとうございます。少しずつイメージできるようになってきました。
2023.05.20 01:09
jjon-comさん 
FE ゴールドマイスター
(No.8)
No.6の文の「後ろ」をすべて「前」に置き換えるのなら正しいです。

ただこれは、「前」「後ろ」をどうイメージしているかの違いかもしれません。

→[大崎]→[品川]→[田町]→ において現在位置が[品川]であるとき、

私は、
[大崎]を [品川]の「前」と呼ぶ方がしっくりきますし、
[田町]を [品川]の「後ろ」と呼ぶ方がしっくりきます。

それに対してSato39さんは、
[田町]を [品川]の「前」と呼ぶイメージ、
[大崎]を [品川]の「後ろ」と呼ぶイメージなのかもしれません。
2023.05.21 10:26

返信投稿用フォーム

スパム防止のためにスレッド作成日から30日経過したスレッドへの投稿はできません。

その他のスレッド


Pagetop