Pseudo-polynomiální čas - Pseudo-polynomial time
v teorie výpočetní složitosti, běží numerický algoritmus pseudo-polynomiální čas Pokud je to provozní doba je polynomiální v číselná hodnota vstupu (největší celé číslo na vstupu) - ale ne nutně v délka vstupu (počet bitů potřebných k jeho reprezentaci), což je případ polynomiální čas algoritmy.
Obecně platí, že numerická hodnota vstupu je ve vstupní délce exponenciální, a proto pseudo-polynomiální časový algoritmus nemusí nutně běžet v polynomiálním čase s ohledem na vstupní délku.
An NP-kompletní nazývá se problém se známými časovými algoritmy pseudo-polynomu slabě NP-kompletní.An NP-kompletní problém se nazývá silně NP-kompletní pokud je prokázáno, že to nelze vyřešit algoritmem pseudo-polynomiálního času, pokud P = NP. Silné / slabé druhy NP-tvrdost jsou definovány analogicky.
Příklady
Testování originality
Zvažte problém testování, zda číslo n je hlavní tím, že naivně zkontrolujete, zda v systému není číslo rozděluje rovnoměrně. Tento přístup může trvat až divize, která je sublineární v hodnota n ale exponenciální v délka n (což je asi ). Například číslo n o něco méně než 10,000,000,000 by vyžadovalo až přibližně 100 000 divizí, i když by to byla délka n je pouze 11 číslic. Navíc lze snadno zapsat vstup (řekněme 300místné číslo), pro který je tento algoritmus nepraktický. Protože výpočetní složitost měří obtíže s ohledem na délka (zakódovaného) vstupu je tento naivní algoritmus ve skutečnosti exponenciální. To je, nicméně, pseudo-polynomial čas.
Porovnejte tento algoritmus se skutečným polynomiálním numerickým algoritmem - řekněme přímý algoritmus pro přidání: Přidání dvou 9místných čísel trvá přibližně 9 jednoduchých kroků a obecně je algoritmus v délce vstupu skutečně lineární. Ve srovnání se skutečnými přidávanými čísly (v miliardách) lze algoritmus nazvat „pseudo-logaritmickým časem“, i když takový termín není standardní. Přidávání 300místných čísel tedy není nepraktické. Podobně je dlouhé dělení kvadratické: an m-místné číslo lze rozdělit a n-místné číslo v kroky (viz Velká O notace.)
V případě primality se ukázalo, že existuje jiný algoritmus pro testování zda n je hlavní (objeveno v roce 2002), které běží v čase .
Problém s batohem
V batoh problém, je nám dáno položky s hmotností a hodnota , spolu s maximální nosností batohu Cílem je vyřešit následující optimalizační problém; neformálně, jaký je nejlepší způsob, jak umístit předměty do batohu, abyste maximalizovali hodnotu?
- maximalizovat
- podléhá a .
Řešení tohoto problému je NP-tvrdé, takže polynomiální časový algoritmus je nemožný, pokud P = NP. Nicméně, je možné použít časový algoritmus dynamické programování; od čísla jen potřebuje bitů k popisu, tento algoritmus běží v pseudo-polynomiálním čase.
Zobecnění na nečíselné problémy
Ačkoli se pojem pseudo-polynomiálního času používá téměř výlučně pro numerické problémy, lze koncept zobecnit: m je pseudo-polynom, pokudm(n) není větší než a polynomiální funkce z velikost problému n a další vlastnost vstupu, k(n). (Pravděpodobně, k je vybráno jako něco relevantního k problému.) Díky tomu jsou numerické polynomické problémy zvláštním případem k být číselná hodnota vstupu.
Rozdíl mezi hodnotou čísla a jeho délkou je jeden z kódování: pokud jsou vždy zakódovány číselné vstupy unární, pak pseudo-polynom se shodovat s polynomiální.
Viz také
Reference
- Michael R. Garey a David S. Johnson. Počítače a neodolatelnost: Průvodce po teorii NP-úplnosti. W.H. Freeman and Company, 1979.