Algoritma Grafik

Grafik adalah notasi abstrak yang digunakan untuk merepresentasikan hubungan antar pasangan objek. Grafik terdiri dari -

  • Vertices- Objek yang saling berhubungan dalam grafik disebut simpul. Simpul juga dikenal sebagainodes.

  • Edges - Tepi adalah penghubung yang menghubungkan simpul.

Ada dua jenis grafik -

  • Directed graph - Pada graf berarah, sisi-sisi memiliki arah, yaitu sisi-sisi berpindah dari satu simpul ke simpul lainnya.

  • Undirected graph - Pada graf tidak berarah, tepi tidak memiliki arah.

Pewarnaan Grafik

Pewarnaan graf adalah metode untuk menetapkan warna pada simpul dari sebuah graf sehingga tidak ada dua simpul yang berdekatan memiliki warna yang sama. Beberapa masalah pewarnaan grafik adalah -

  • Vertex coloring - Cara mewarnai simpul pada grafik sehingga tidak ada dua simpul yang berdekatan memiliki warna yang sama.

  • Edge Coloring - Ini adalah metode pemberian warna ke setiap tepi sehingga tidak ada dua tepi yang berdekatan memiliki warna yang sama.

  • Face coloring - Ini memberikan warna untuk setiap permukaan atau wilayah dari grafik planar sehingga tidak ada dua permukaan yang berbagi batas yang sama memiliki warna yang sama.

Nomor Chromatic

Bilangan kromatik adalah jumlah warna minimum yang dibutuhkan untuk mewarnai grafik. Misalnya, bilangan kromatik dari grafik berikut adalah 3.

Konsep pewarnaan graf diterapkan dalam penyusunan jadwal, penetapan frekuensi radio bergerak, suduku, alokasi register, dan pewarnaan peta.

Langkah-langkah pewarnaan grafik

  • Tetapkan nilai awal setiap prosesor dalam larik berdimensi-n ke 1.

  • Sekarang untuk menetapkan warna tertentu ke simpul, tentukan apakah warna itu sudah ditetapkan ke simpul yang berdekatan atau belum.

  • Jika prosesor mendeteksi warna yang sama di simpul yang berdekatan, itu menetapkan nilainya dalam larik ke 0.

  • Setelah membuat n 2 perbandingan, jika ada elemen dari larik yang bernilai 1, maka itu adalah pewarnaan yang valid.

Pseudocode untuk pewarnaan grafik

begin

   create the processors P(i0,i1,...in-1) where 0_iv < m, 0 _ v < n
   status[i0,..in-1] = 1
	
   for j varies from 0 to n-1 do
      begin
		
         for k varies from 0 to n-1 do
         begin
            if aj,k=1 and ij=ikthen
            status[i0,..in-1] =0
         end
			
      end
      ok = ΣStatus
		
   if ok > 0, then display valid coloring exists
   else
      display invalid coloring
      
end

Minimal Spanning Tree

Pohon bentang yang jumlah berat (atau panjang) semua tepinya kurang dari semua pohon bentang lain yang mungkin dari grafik G dikenal sebagai a minimal spanning tree atau minimum cost spanningpohon. Gambar berikut menunjukkan grafik terhubung berbobot.

Beberapa pohon rentang yang mungkin dari grafik di atas ditunjukkan di bawah -

Di antara semua pohon bentang di atas, gambar (d) adalah pohon bentang minimum. Konsep pohon rentang biaya minimum diterapkan dalam masalah travelling salesman, merancang sirkuit elektronik, Merancang jaringan yang efisien, dan merancang algoritma perutean yang efisien.

Untuk menerapkan pohon rentang biaya minimum, dua metode berikut digunakan -

  • Algoritma Prim
  • Algoritma Kruskal

Algoritma Prim

Algoritme Prim adalah algoritme serakah, yang membantu kami menemukan pohon rentang minimum untuk grafik tak berarah berbobot. Ia memilih sebuah simpul terlebih dahulu dan menemukan sebuah sisi dengan kejadian bobot terendah pada simpul tersebut.

Langkah-langkah Algoritma Prim

  • Pilih sembarang titik, ucapkan v 1 dari Grafik G.

  • Pilih sebuah tepi, katakanlah e 1 dari G sehingga e 1 = v 1 v 2 dan v 1 ≠ v 2 dan e 1 memiliki bobot minimum di antara sisi-sisi yang bersisian pada v 1 dalam grafik G.

  • Sekarang, mengikuti langkah 2, pilih insiden tepi berbobot minimum pada v 2 .

  • Lanjutkan ini sampai n – 1 tepi telah dipilih. Sinin adalah jumlah simpul.

Pohon rentang minimum adalah -

Algoritma Kruskal

Algoritme Kruskal adalah algoritme serakah, yang membantu kita menemukan pohon rentang minimum untuk grafik berbobot yang terhubung, menambahkan busur biaya yang semakin meningkat di setiap langkah. Ini adalah algoritma pohon perentang minimum yang menemukan tepi dengan bobot sekecil mungkin yang menghubungkan dua pohon di hutan.

Langkah-langkah Algoritma Kruskal

  • Pilih tepi dengan berat minimum; katakanlah e 1 dari Grafik G dan e 1 bukan sebuah loop.

  • Pilih tepi berbobot minimum berikutnya yang terhubung ke e 1 .

  • Lanjutkan ini sampai n – 1 tepi telah dipilih. Sinin adalah jumlah simpul.

Pohon rentang minimum dari grafik di atas adalah -

Algoritma Jalur Terpendek

Algoritma Shortest Path adalah metode untuk mencari jalur dengan biaya terkecil dari node sumber (S) ke node tujuan (D). Di sini, kita akan membahas algoritma Moore, juga dikenal sebagai Algoritma Pencarian Pertama Luas.

Algoritme Moore

  • Beri label simpul sumber, S dan beri label i dan set i=0.

  • Temukan semua simpul tak berlabel yang berdekatan dengan simpul berlabel i. Jika tidak ada simpul yang terhubung ke simpul, S, maka simpul, D, tidak terhubung ke S. Jika ada simpul terhubung ke S, beri labeli+1.

  • Jika D diberi label, lanjutkan ke langkah 4, jika tidak lanjutkan ke langkah 2 untuk meningkatkan i = i + 1.

  • Berhenti setelah panjang jalan terpendek ditemukan.