Sözde polinom zaman - Pseudo-polynomial time

İçinde hesaplama karmaşıklığı teorisi sayısal bir algoritma çalışır sözde polinom zaman eğer onun çalışma süresi bir polinom içinde Sayısal değer Girdinin (girdide bulunan en büyük tam sayı) - ancak uzunluk girdinin (onu temsil etmek için gereken bit sayısı), ki bu durum polinom zamanı algoritmalar.

Genel olarak, girdinin sayısal değeri girdi uzunluğunda üsteldir, bu nedenle sözde-polinom zaman algoritması, girdi uzunluğuna göre polinom zamanda mutlaka çalışmaz.

Bir NP tamamlandı bilinen sözde polinom zaman algoritmalarıyla ilgili problem denir zayıf NP tamamlandı. Bir NP tamamlandı sorun denir kesinlikle NP-tamamlandı sözde polinom zaman algoritması ile çözülemeyeceği kanıtlanırsa P = NP. Güçlü / zayıf türleri NP sertliği benzer şekilde tanımlanmıştır.

Örnekler

Asallık testi

Sorununu düşünün bir sayı olup olmadığını test etmek n asal, safça kontrol ederek böler eşit olarak. Bu yaklaşım kadar sürebilir alt doğrusal olan bölümler n değeri ama üstel n uzunluğu (hangisi hakkında ). Örneğin bir sayı n biraz daha az 10,000,000,000 uzunluğu olsa bile yaklaşık 100.000 bölüm gerektirir. n sadece 11 basamaktır. Dahası, bu algoritmanın pratik olmadığı bir girdi (örneğin 300 basamaklı bir sayı) kolayca yazılabilir. Hesaplama karmaşıklığı, uzunluk (kodlanmış) girdinin bu saf algoritması aslında üsteldir. O dır-dirancak sözde polinom zamanı.

Bu algoritmayı gerçek bir polinom sayısal algoritma ile karşılaştırın - örneğin, toplama için basit algoritma: 9 basamaklı iki sayının eklenmesi yaklaşık 9 basit adım alır ve genel olarak algoritma, girdinin uzunluğu açısından gerçekten doğrusaldır. Eklenen gerçek sayılarla (milyarlarca) karşılaştırıldığında, algoritma "sözde-logaritmik zaman" olarak adlandırılabilir, ancak böyle bir terim standart değildir. Bu nedenle, 300 basamaklı sayılar eklemek pratik değildir. Benzer şekilde, uzun bölme ikinci dereceden: bir mbasamaklı sayı bir ile bölünebilir nbasamaklı sayı adımlar (bakınız Büyük O gösterimi.)

İlkellik durumunda, farklı bir algoritma olduğu ortaya çıktı. olup olmadığını test etmek n asal (2002'de keşfedildi) zamanında çalışan .

Sırt çantası sorunu

İçinde sırt çantası sorunu biz verildik ağırlığa sahip ürünler ve değer bir sırt çantasının maksimum ağırlık kapasitesiyle birlikte Amaç, aşağıdaki optimizasyon problemini çözmektir; gayri resmi olarak, değeri en üst düzeye çıkarmak için eşyaları sırt çantasına yerleştirmenin en iyi yolu nedir?

maksimize etmek
tabi ve .

Bu sorunu çözmek NP-zor dolayısıyla polinom zaman algoritması, P = NP. Ancak, bir zaman algoritması kullanılarak mümkündür dinamik program; numaradan beri sadece ihtiyaçlar bitleri açıklamak gerekirse, bu algoritma sözde polinom zamanda çalışır.

Sayısal olmayan problemlere genelleme

Sözde polinom zaman kavramı neredeyse sadece sayısal problemler için kullanılsa da, kavram genelleştirilebilir: m sözde polinom isem(n) a'dan büyük değildir Polinom fonksiyonu of problem boyutu n ve girdinin ek bir özelliği, k(n). (Muhtemelen, k problemle ilgili bir şey olarak seçilir.) Bu, sayısal polinom problemlerini özel bir durum haline getirir. k girdinin sayısal değeri.

Bir sayının değeri ile uzunluğu arasındaki ayrım, kodlamadan biridir: eğer sayısal girdiler her zaman birli, sonra sözde polinom ile çakışacak polinom.

Ayrıca bakınız

Referanslar