
No.2ベストアンサー
- 回答日時:
まあ構造としては「木はグラフの特殊なもの」「パスは木の特殊なもの」なので
グラフ構造 > 木構造 > リスト構造
ではありますが, 普通はそれぞれ適切なものを使うと思います. リストを表現するときにグラフ構造を使うことは可能かもしれないけど, かなり無駄な感じ.
この回答へのお礼
お礼日時:2008/08/09 20:09
回答ありがとうございます。
なんかちゃんと定義されていないのって気持ち悪いんですよねぇ。
スッキリするまでグラフ理論を勉強しようと思います。
ありがとうございました。
No.1
- 回答日時:
・map
「キーと値のペア」の集まりで、キーに対して値が一意に定まるもの(キーの重複が許されないもの)。
値の重複は許されるので、一対一だけでなく多対1の関係も含みます。
・set
値の集まりで、値の重複が許されないもの。
mapにおけるキーと値をひとかたまりとみなせば、同じようなもの、と考えることもできると思います。
数学で言うところの集合→set、写像→mapでよいと思います。
・table/list
mapとsetが論理的で、機能に言及した分類(どのような制約があるか等)であることに比較すると、table/listは、実装方法による分類というイメージになります。
キーや値の重複を許す/許さないといった点には言及せず、計算コスト(特定の値を持つ要素を見つけるのにどれだけ時間がかかるか等)が(データ構造の)利用者から見えるものとして定められます。
すごく実装を意識して説明すると、
・table
値の集まりで、値が連続的な領域に配置されているもの。
(連続的な領域に配置されていて、位置が既知のため)任意の値にダイレクトにアクセスできる。
映画館の座席の番号とか、マンションの部屋番号とか、番号が分かれば位置が直接特定できるようなイメージです。
・list
値(要素)の集まりで、ある要素からは、その近隣(次、とか前とか)の要素にしかアクセスできない。
一般に、鎖状(1次元)の構造を成す。
よいイメージが思いつきませんが。。。
車内に路線図のない路線バスに乗って「次は○○です」といわれるのを聞きながら目的地に到達するような感じです。。分かりづらいですね^^;;
参考までに、、
機能的な面に着目したデータ構造というと、他にはキューやスタックなどがあります。
実装、構造に着目したデータ構造というと、他には木(tree)構造やグラフがあります。
C++を勉強中でしたら、標準テンプレートライブラリ(STL)の書籍等で分かりやすく説明されているのではと思います。
この回答への補足
もう一つ疑問なのですが、
リスト構造はツリー構造の一種なのでしょうか?
○<->○<->○<->○
分類すると
グラフ > ツリー構造 > リスト構造
なのでしょうか?
回答して頂いて大変あつかましいのですが、宜しくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
画像生成AIのプロンプトの作り...
-
vba 正規表現について教えてく...
-
pythonでのローカルファイルか...
-
if関数とは?
-
プログラム言語
-
今のプログラミング言語
-
vba クリップボードクリアにつ...
-
itエンジニアに就職希望で未経...
-
Pythonのエラーメッセージをコ...
-
P2P地震速報のEEW APIの仕様書...
-
著作権法について
-
プログラミングについて
-
自作scratch アニメの商用利用
-
Geminiフォーム 画像生成で 人...
-
数学、プログラミング、物理、...
-
Python 3.12.2 か一番最新のパ...
-
MOVEコマンドでサブフォルダー...
-
AIがプログラムする時代のプロ...
-
pythonについて(初心者です)
-
pythonでhtmlファイルの指定文...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語 exitの使い方
-
フォームを開くときに、コンボ...
-
Excel-vba 文字列と変数を...
-
VB6.0-整数と余りを求める
-
ラジオボタンの値の取得につい...
-
足して100になるような乱数のア...
-
VBAで配列のNULL判定
-
VBA コンボボックスの値をスピ...
-
データ構造のmapとは?
-
VBAの定数の使い方で、計算値を...
-
フリーランタイマーの時間差分...
-
1つ前の値を変数に保存する方法
-
C#で動的にコントロールを取得...
-
コンボボックスの名前を変数に...
-
UWSCのcallについて
-
Nullってどういう意味ですか?
-
DWORDって
-
[シェルスクリプト] 空文字の判...
-
Access2003 オートナンバーの現...
-
2つの列で重複するキーの数と...
おすすめ情報