Paralel Arama Algoritması

Arama, bilgisayar bilimindeki temel işlemlerden biridir. Bir elemanın verilen listede olup olmadığını bulmamız gereken tüm uygulamalarda kullanılır. Bu bölümde aşağıdaki arama algoritmalarını tartışacağız -

  • Böl ve fethet
  • Derinlik öncelikli arama
  • Kapsamlı Arama
  • En İyi İlk Arama

Böl ve fethet

Böl ve yönet yaklaşımında, problem birkaç küçük alt probleme bölünmüştür. Daha sonra alt problemler özyinelemeli olarak çözülür ve orijinal problemin çözümünü elde etmek için birleştirilir.

Böl ve yönet yaklaşımı, her seviyede aşağıdaki adımları içerir -

  • Divide - Asıl problem alt problemlere bölünmüştür.

  • Conquer - Alt problemler özyinelemeli olarak çözülür.

  • Combine - Alt problemlerin çözümleri birleştirilerek asıl problemin çözümü elde edilir.

İkili arama, böl ve yönet algoritmasına bir örnektir.

Sözde kod

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)

Derinlik öncelikli arama

Derinlik-İlk Arama (veya DFS), bir ağaçta veya yönlendirilmemiş bir grafik veri yapısında arama yapmaya yönelik bir algoritmadır. Burada konsept, başlangıç ​​noktası olarak bilinen başlangıç ​​düğümünden başlamaktır.rootve aynı dalda olabildiğince uzağa gidin. Ardıl düğümü olmayan bir düğüm alırsak, geri döner ve henüz ziyaret edilmemiş olan tepe noktasından devam ederiz.

Derinlik İlk Arama Adımları

  • Daha önce ziyaret edilmemiş bir düğüm (kök) düşünün ve ziyaret edildi olarak işaretleyin.

  • İlk bitişik halef düğümü ziyaret edin ve ziyaret edildi olarak işaretleyin.

  • Dikkate alınan düğümün tüm ardıl düğümleri zaten ziyaret edilmişse veya başka bir ardıl düğüme sahip değilse, ana düğümüne dönün.

Sözde kod

İzin Vermek v Grafikte aramanın başladığı tepe noktası olun 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()

Kapsamlı Arama

Genişlik İlk Arama (veya BFS), bir ağaç veya yönlendirilmemiş bir grafik veri yapısını aramak için bir algoritmadır. Burada bir düğümle başlıyoruz ve ardından aynı seviyedeki tüm bitişik düğümleri ziyaret ediyoruz ve ardından bir sonraki seviyedeki bitişik halef düğüme geçiyoruz. Bu aynı zamandalevel-by-level search.

Kapsamlı Arama Adımları

  • Kök düğümle başlayın, ziyaret edildi olarak işaretleyin.
  • Kök düğümün aynı düzeyde düğümü olmadığından, bir sonraki düzeye geçin.
  • Tüm bitişik düğümleri ziyaret edin ve ziyaret edildi olarak işaretleyin.
  • Bir sonraki seviyeye gidin ve ziyaret edilmeyen tüm bitişik düğümleri ziyaret edin.
  • Tüm düğümler ziyaret edilene kadar bu işleme devam edin.

Sözde kod

İzin Vermek v Grafikte aramanın başladığı tepe noktası olun 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()

En İyi İlk Arama

En İyi İlk Arama, bir hedefe mümkün olan en kısa yoldan ulaşmak için bir grafiği tarayan bir algoritmadır. BFS ve DFS'nin aksine, En İyi İlk Arama, hangi düğümün bir sonraki geçiş için en uygun olduğunu belirlemek için bir değerlendirme işlevini izler.

En İyi İlk Aramanın Adımları

  • Kök düğümle başlayın, ziyaret edildi olarak işaretleyin.
  • Sonraki uygun düğümü bulun ve ziyaret edildi olarak işaretleyin.
  • Bir sonraki seviyeye gidin ve uygun düğümü bulun ve ziyaret edildi olarak işaretleyin.
  • Hedefe ulaşılana kadar bu işleme devam edin.

Sözde kod

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