Existe-t-il des problèmes NP-complets pour lesquels des algorithmes sous-exponentiels ont fait leurs preuves?
Je demande des informations générales sur les cas, je ne parle pas de cas particuliers traitables ici.
Par sub-exponentielle, j'entends un ordre de croissance supérieur aux polynômes, mais moins qu'exponentiel, par exemple .
Réponses:
Cela dépend de ce que vous entendez par subexponential. Ci-dessous, j'explique quelques significations de "sous-exponentiel" et de ce qui se passe dans chaque cas. Chacune de ces classes est contenue dans les classes ci-dessous.
I.2no(1)
Si vous entendez par subexpoential , alors une conjecture en théorie de la complexité appeléehypothèse de temps exponentiel (ETH)supposequ'aucunproblèmeNP-hard ne peut avoir un algorithme avec le temps d'exécution2 n o ( 1 )2no(1) NP 2no(1) .
Notez que cette classe est fermée sous composition avec polynômes. Si nous avons un algorithme temporel sous-exponentiel pour toutNP problème de, nous pouvons combiner avec une réduction du temps polynomiale de SAT à lui obtenir un algorithme sousexponentiel pour 3SAT qui irait à l' encontre des EPF.
II. ,savoir2 O ( n ε ) pourtout0<ε⋂0<ϵ2O(nϵ) 2O(nϵ) 0<ϵ
La situation est similaire à la précédente.
Il est fermé sous les polynômes de sorte qu'aucun problème hard ne peut être résolu à ce moment-là sans violer ETH.N P
III. ,savoir2 O ( n ε ) pourcertainε<1⋃ε < 12O ( nε) 2O ( nε) ε < 1
Si par sousexponentiel vous moyenne pour un certain ε < 1 alors la réponse est oui, il y a démontrable de tels problèmes.2O ( nε) ε < 1
Prendre un problème -complete comme SAT. Il a un algorithme de force brute qui court dans le temps 2 O ( n ) . Considérons maintenant la version complétée de SAT en ajoutant une chaîne de taille n k aux entrées:N P 2O ( n ) nk
Maintenant, ce problème est dur et peut être résolu dans le temps 2 O ( n 1N P .2O ( n1k)
IV2o ( n )
Cela contient la classe précédente, la réponse est similaire.
V.⋂0 < ε2ϵ n , soit pour tout ε > 02ϵ n ε > 0
Cela contient la classe précédente, la réponse est similaire.
VI.⋃ε < 12ϵ n , soit pour un certain ε < 12ϵ n ε < 1
Cela contient la classe précédente, la réponse est similaire.
Que signifie subexponential?
"Au-dessus de polynôme" n'est pas une limite supérieure, mais une limite inférieure et est appelé superpolynôme .
Des fonctions comme s'appellent quasipolynomialnlgn , et comme son nom l' indique sont presque polynomiale et loin d'être exponentielle, sousexponentiel est généralement utilisé pour désigner une classe beaucoup plus de fonctions avec des taux beaucoup plus rapide croissance.
Comme son nom l'indique, "subexponential" signifie plus lent que exponentiel . Par exponentielle, nous entendons généralement les fonctions de classe , ou de la classe plus agréable 2 n Θ ( 1 ) (fermée sous composition avec des polynômes).2Θ ( n ) 2nΘ ( 1 )
Le sous-exponentiel devrait être proche de ceux-ci mais plus petit. Il y a différentes façons de le faire et il n'y a pas de signification standard. Nous pouvons remplacer par o dans les deux définitions d’exponentielle et obtenir I et IV. La bonne chose à leur sujet est qu'ils sont uniformément définis (pas quantificateurs sur ε ). Nous pouvons remplacer Θ avec un coefficient multiplicatif ε pour tout ε > 0Θ o ε Θ ε ε > 0 , nous obtenons II et V. Leur sont proches de I et IV , mais non uniforme définis. La dernière option est de remplacer avec une constante multiplicatif ε pour une ε < 1 . Cela donne II et VI.Θ ε ε < 1
Lequel devrait être appelé subexponential est discutable. Les gens utilisent généralement celui dont ils ont besoin dans leur travail et le qualifient de subexponentiel.
I est ma préférence personnelle, c’est une belle classe: elle est fermée sous composition avec des polynômes et elle est définie uniformément. Il est similaire à qui utilise 2 n O ( 1 ) .E x p 2nO ( 1 )
II semble être utilisé dans la définition de la classe de complexité .S u b e x p
III est utilisé pour les limites supérieures algorithmiques, comme celles mentionnées dans la réponse de Pal.
IV est également commun.
V est utilisé pour énoncer la conjecture ETH.
Estival
la source
la source