병렬 검색 알고리즘

검색은 컴퓨터 과학의 기본 작업 중 하나입니다. 요소가 주어진 목록에 있는지 여부를 찾아야하는 모든 응용 프로그램에서 사용됩니다. 이 장에서는 다음 검색 알고리즘에 대해 설명합니다.

  • 분할 및 정복
  • 깊이 우선 검색
  • 폭 우선 검색
  • 최우선 검색

분할 및 정복

분할 및 정복 접근법에서 문제는 몇 가지 작은 하위 문제로 나뉩니다. 그런 다음 하위 문제를 재귀 적으로 해결하고 결합하여 원래 문제의 솔루션을 얻습니다.

분할 및 정복 접근법은 각 수준에서 다음 단계를 포함합니다.

  • Divide − 원래 문제는 하위 문제로 나뉩니다.

  • Conquer − 하위 문제는 재귀 적으로 해결됩니다.

  • Combine − 하위 문제의 해를 결합하여 원래 문제의 해를 구합니다.

이진 검색은 분할 및 정복 알고리즘의 예입니다.

의사 코드

Binarysearch(a, b, low, high)

if low < high then
   return NOT FOUND
else
   mid ← (low+high) / 2
   if b = key(mid) then
      return key(mid)
   else if b < key(mid) then
      return BinarySearch(a, b, low, mid−1)
   else
   
      return BinarySearch(a, b, mid+1, high)

깊이 우선 검색

깊이 우선 검색 (또는 DFS)은 트리 또는 무 방향 그래프 데이터 구조를 검색하기위한 알고리즘입니다. 여기에서 개념은 시작 노드에서 시작하는 것입니다.root같은 지점에서 가능한 한 멀리 횡단합니다. 후속 노드가없는 노드를 얻으면 아직 방문하지 않은 정점으로 돌아가 계속합니다.

깊이 우선 검색 단계

  • 이전에 방문하지 않은 노드 (루트)를 고려하고 방문한 것으로 표시하십시오.

  • 첫 번째 인접 후속 노드를 방문하여 방문한 것으로 표시합니다.

  • 고려 된 노드의 모든 후속 노드가 이미 방문되었거나 더 이상 후속 노드가없는 경우 상위 노드로 돌아갑니다.

의사 코드

허락하다 v 그래프에서 검색이 시작되는 꼭지점 G.

DFS(G,v)

   Stack S := {};
	
   for each vertex u, set visited[u] := false;
   push S, v;
   while (S is not empty) do
     u := pop S;
	  
      if (not visited[u]) then
         visited[u] := true;
         for each unvisited neighbour w of u
            push S, w;
      end if
		
   end while
   
END DFS()

폭 우선 검색

BFS (Breadth-First Search)는 트리 또는 무 방향 그래프 데이터 구조를 검색하는 알고리즘입니다. 여기서는 노드로 시작한 다음 동일한 수준의 모든 인접 노드를 방문한 다음 다음 수준의 인접한 후속 노드로 이동합니다. 이것은 또한 알려진level-by-level search.

폭 우선 검색의 단계

  • 루트 노드로 시작하여 방문한 것으로 표시하십시오.
  • 루트 노드에는 같은 수준의 노드가 없으므로 다음 수준으로 이동합니다.
  • 인접한 모든 노드를 방문하고 방문한 것으로 표시하십시오.
  • 다음 레벨로 이동하여 방문하지 않은 모든 인접 노드를 방문하십시오.
  • 모든 노드를 방문 할 때까지이 프로세스를 계속하십시오.

의사 코드

허락하다 v 그래프에서 검색이 시작되는 꼭지점 G.

BFS(G,v)

   Queue Q := {};
	
   for each vertex u, set visited[u] := false;
   insert Q, v;
   while (Q is not empty) do
      u := delete Q;
		
      if (not visited[u]) then
         visited[u] := true;
         for each unvisited neighbor w of u
            insert Q, w;
      end if
		
   end while
   
END BFS()

최우선 검색

Best-First Search는 가능한 최단 경로에서 목표에 도달하기 위해 그래프를 순회하는 알고리즘입니다. BFS 및 DFS와 달리 Best-First Search는 평가 기능을 따라 다음에 순회하기에 가장 적합한 노드를 결정합니다.

Best-First Search 단계

  • 루트 노드로 시작하여 방문한 것으로 표시하십시오.
  • 다음 적절한 노드를 찾아 방문한 것으로 표시하십시오.
  • 다음 레벨로 이동하여 적절한 노드를 찾아 방문한 것으로 표시하십시오.
  • 목표에 도달 할 때까지이 프로세스를 계속하십시오.

의사 코드

BFS( m )

   Insert( m.StartNode )
   Until PriorityQueue is empty
      c ← PriorityQueue.DeleteMin
      If c is the goal
      Exit
   Else
   
      Foreach neighbor n of c
         If n "Unvisited"
            Mark n "Visited"
            Insert( n )
      Mark c "Examined"
      
End procedure