「線形探索」の版間の差分
表示
削除された内容 追加された内容
Krorokeroro (会話 | 投稿記録) 2400:2200:2E1:6A90:CDA:B57F:9B4A:269F (会話) による ID:75673230 の版を取り消し タグ: 取り消し |
|||
31行目: | 31行目: | ||
==プログラム例== |
==プログラム例== |
||
===Common Lisp=== |
===Common Lisp=== |
||
< |
<syntaxhighlight lang="lisp"> |
||
(defun linear-search (list x) |
(defun linear-search (list x) |
||
(dolist (e list) |
(dolist (e list) |
||
37行目: | 37行目: | ||
(return-from linear-search T))) ;found |
(return-from linear-search T))) ;found |
||
NIL) ;not found |
NIL) ;not found |
||
</syntaxhighlight> |
|||
</source> |
|||
===F#=== |
===F#=== |
||
< |
<syntaxhighlight lang="fsharp"> |
||
// For basic sequence: |
// For basic sequence: |
||
let find value (vs: seq<_>) = |
let find value (vs: seq<_>) = |
||
57行目: | 57行目: | ||
else ifind2 (index + 1) (List.tail vl) |
else ifind2 (index + 1) (List.tail vl) |
||
ifind2 0 vl |
ifind2 0 vl |
||
</syntaxhighlight> |
|||
</source> |
|||
===C=== |
===C=== |
||
< |
<syntaxhighlight lang="c"> |
||
/* for integer array: */ |
/* for integer array: */ |
||
int |
int |
||
75行目: | 75行目: | ||
return -1; |
return -1; |
||
} |
} |
||
</syntaxhighlight> |
|||
</source> |
|||
==関連項目== |
==関連項目== |
2020年7月5日 (日) 22:37時点における版
線形探索(せんけいたんさく、英: linear search, sequential search)は、検索のアルゴリズムの一つ。 リストや配列に入ったデータに対する検索を行うにあたって、 先頭から順に比較を行い、それが見つかれば終了する。
個のデータから個のデータを検索する場合、時間計算量は 、空間計算量は である。
アルゴリズムの流れ
下のような7個のデータを持つリストがある。このときに今要素1がどこにあるか、検索したい。
10 | 7 | 12 | 6 | 1 | 4 | 3 |
線形探索では、
- 最初の要素である10を見る。
- 10は1ではないので、次の要素7を見る。
- 7は1ではないので、次の要素12を見る。
- 12は1ではないので、次の要素6を見る。
- 6は1ではないので、次の要素1を見る。1を見つけることができた。
最悪のケースは、このリストの場合、要素3を見つけるときで、7個のデータ全てを見ないと、見つけることができない。
プログラム例
Common Lisp
(defun linear-search (list x)
(dolist (e list)
(when (equal e x)
(return-from linear-search T))) ;found
NIL) ;not found
F#
// For basic sequence:
let find value (vs: seq<_>) =
use e = vs.GetEnumerator()
let rec ifind index =
if e.MoveNext() then
if e.Current = value then Some index else ifind (index + 1)
else None
ifind 0
// For list:
let find2 value vl =
let rec ifind2 index vl =
if List.isEmpty vl then None
else if (List.head vl) = value then Some index
else ifind2 (index + 1) (List.tail vl)
ifind2 0 vl
C
/* for integer array: */
int
find(
int array[],
int array_size,
int value)
{
int i;
for (i = 0; i < array_size; ++i)
{
if (array[i] == value) { return i; }
}
return -1;
}