Kenar kapsama problemi

Vikipedi, özgür ansiklopedi
Atla: kullan, ara

Köşe Örtme (İngilizce: Vertex Cover), bir çizge (graf) içerisindeki tüm kenarların en az sayıda seçilebilecek düğüm ile kapsanabilir olup olmadığının bulunması problemidir. Bu problemin [NP (karmaşıklık)|NP] sınıfı içerisinde olduğu bilinmektedir. Amaç, bu problemin [NP (karmaşıklık)|NP-Tam] sınıfında olup olmadığının ispatıdır.

Köşe Örtme probleminin NP sınıfı içerisinde olduğu zaten görülmektedir. Çünkü NP sınıfındaki bir probleme ilişkin verilen bir çözümün polinom zamanda doğru olup olmadığını tespit etmek mümkündür. Örneğin verilen bir grafın içinde tüm kenarları kapsayan bir alt küme olduğunu iddia eden bir çözümün doğruluğu için O(n2) zaman yeterlidir. Bu çözüm için iç içe iki tane döngü içerisinde düğümler arasındaki ilişkiyi izlemek yeterlidir.

Tanım[değiştir | kaynağı değiştir]

Köşe Örtme={(G,k)| G, k tane düğümlü bir köşe örtme alt kümesine sahip bir graftır.}} Buna göre; SampleVertexCover.gif birer köşe örtme alt kümesine sahip olan graflardır.

köşe örtme Probleminin NP-Tam İçinde Yer Aldığının İspatı[değiştir | kaynağı değiştir]

Bir problemin NP-Tam olduğunu ispat etmek için, daha önce NP-Tam olduğu bilinen bir problemin bu probleme polinom zamanda indirgeniyor olduğunu ispat etmek yeterlidir.

Bunun için 3SAT probleminin NP-Tam olduğunun bilinmesinden yola çıkarak 3SAT <p köşe örtme(Vertex Cover) ispat edilmesi halinde köşe örtme probleminin de NP-Tam olduğu ispatlanmış olur.

Bunun için öncelikle 3SAT probleminin her bir şart cümleciğinin k tane terim ile gösteriliyor olduğunu bilmek gerekmektedir. Örneğin;

f=(x1 OR x1 OR x2)AND(!x1 OR !x2 OR !x2)AND(!x1 OR x2 OR x2)

şeklinde verilmiş 3SAT problemine uygun bir formülü graf şekline çevirmek gerekmektedir. Böylece bir 3SAT problemi graf haline çevrilmiş olur. Yukarıda verilmiş formülün graf haline çevrilmesi esnasında şu yol izlenmektedir.

Önce şart cümlecikleri içinde geçen terimler ile o terimlerin "DEĞİL" leri arasında bir kenar oluşturacak şekilde graf çizilmeye başlanır. Daha sonra şart cümleciklerini de grafa ekleyerek aynı terimleri birbirine bağlayarak graf oluşturulur. Buna göre m terim sayısı, l şart cümleciği sayısı olarak düşünülürse, 2m+3l tane düğümden oluşan bir graf ortaya çıkar. Verilen grafın içinden tüm köşeleri örtme bir düğüm alt kümesinin eleman sayısını da m+2l olarak farzedelim.

3sattovertex.jpg

Buradaki örnekte k=8 olarak bulunur.

Bundan sonraki adım ise, köşe örtme algoritmasını gerçekleyecek ve bu koşulları olumlu olarak mantıksal doğrulanabilir sağlayacak bir karşılanabilirlik ifadesi çıkarılır. Bunun için önce grafta terimlere "doğru" karşılık gelecek kısımları seçilir. Daha sonra bu seçimin ardından, şart cümleciklerinin içinden öylesine ikişer tane düğüm seçilir ki, hem grafın kenarlarının tamamı kapsanabilir olur hem de formülde verilen şart cümleciklerinin her birisi mantıksal doğrulanabilir olur. Bunun için eğer; x1 "YANLIŞ" , x2 "DOĞRU" seçilirse, o zaman yukarıdaki terimlerden !x1 ve x2 seçilip aşağıdaki şart cümleciklerinden de taralı kısımların seçilmesiyle, graftaki tüm köşe örtme olmasının yanı sıra, x1 ve x2 değerlerinin şart cümlecikleri içerisinde yerine konulmasıyla da şart cümleciklerinin her birinin mantıksal doğrulanaiblir olduğu görülür. Tüm bu işlemlerin yapılması polinom zamanda gerçeklenebildiğinden, 3SAT problemini polinom zamanda köşe örtme problemi haline dönüşebildiğinden köşe örtme problemi de NP-Tam sınıfındadır.

(x1 OR x1 OR x2)=(YANLIŞ OR YANLIŞ OR DOĞRU) =DOĞRU

(!x1 OR !x2 OR !x2)=(DOĞRU OR YANLIŞ OR YANLIŞ)=DOĞRU

(!x1 OR x2 OR x2)=(DOĞRU OR DOĞRU OR DOĞRU)=DOĞRU

Böylece yukarıdaki tüm şart cümlecikleri mantıksal doğrulanabilir olmasının yanı sıra, graf üzerinde 8 tane düğümün seçilerek tüm

köşeleri örten bir alt küme bulunmuş olur.

Buna göre oluşan grafın son hali aşağıdaki şekilde gösterildiği gibi olmaktadır.

VCexample.gif

Kaynakça[değiştir | kaynağı değiştir]