P/NP問題

計算機科學中有關時間複雜性的未解決問題

P/NP問題理論計算機科學計算複雜度理論領域至今未解決的問題,是克雷數學研究所七題千禧年大獎難題之一。P/NP問題包括複雜度類PNP的關係。1971年由史提芬·古克(Stephen A. Cook)和列昂尼德·列文英語Leonid Levin分別提出。

複雜度類P即為所有可以由一個確定型圖靈機多項式表達的時間內解決的問題;類NP由所有可以在多項式時間內驗證它的解是否正確的決定問題組成,或者等效的說,那些可以在非確定型圖靈機上在多項式時間內找出解的問題的集合。很可能,計算理論最大的未解決問題就是關於這兩類的關係的:

PNP相等

在2002年對於100研究者的調查中,61人相信答案是否定的,9人相信答案是肯定的,22人不確定,而8人相信問題可能和現在所接受的公理獨立,所以不可能證明或證否。[1]對於正確的解答,有一個一百萬美元的獎勵

NP-完全問題(或者叫NPC)的集合在這討論有重大作用,它們可以大致的描述為那些在NP中最不像在P中的(確切定義細節請參看NP-完全理論)。計算機科學家現在相信PNPNPC類之間的關係如圖中所示,其中PNPC類不相交。

 
假設PNP的複雜度類的圖解。如P=NP則三個類相同。

簡單來說,P=NP即:「若問題的答案可以很快驗證,其答案是否也可以很快被計算出來。」

例如某大數是否合數:如53308290611有否非平凡因數。答案是肯定的,雖然人手找出一個因數很麻煩。從另一個方面講,如果有人聲稱答案是「對,224737可以整除53308290611」,則我們可以很快用除法驗證。驗證一個數是除數比找出一個明顯除數來簡單得多。用於驗證一個正面答案所需的信息也稱為證明。所以我們的結論是,給定正確的證明,問題的正面答案可以很快(也就是,在多項式時間內)驗證,而這就是這個問題屬於NP的原因。

雖然這個特定的問題,最近也獲證實在P類中(參看下面的關於"質數在P中"的參考),這一點也不明顯,而且有很多類似的問題相信不屬於類P

像上面這樣,把問題限制到「是/不是」問題並沒有改變原問題(即沒有降低難度);即使我們允許更複雜的答案,最後的問題(是否FP=FNP)是等價的。

學術定義

編輯

更正式一些,一個決定問題是一個取一些字符串為輸入並要求輸出為是或否的問題。若有一個算法(譬如圖靈機,或一個LISPPascal的程序並有無限的內存)能夠在最多nk步內對一個串長度為n的輸入給出正確答案,其中k是某個不依賴於輸入串的常數,則我們稱該問題可以在多項式時間內解決,並且將它置入類P。直觀的講,我們將P中的問題視為可以較快解決的問題。

現在假設有一個算法A(w,C)取兩個參數,一個串w,也就是我們的決定問題的輸入串,而另一個串C是「建議證明」,並且使得A在最多nk步內產生「是/否」答案(其中nw的長度而k不依賴於w)。然後假設:w是一個答案為「是」的例子,當且僅當,存在C使得A(w,C)返回「是」。 則我們稱這個問題可以在非決定性多項式時間內解決,且將它放入NP類。我們把算法A作為一個所建議的證明的檢驗器,它運行足夠快。(注意縮寫NP代表「Non-deterministic(非確定性)Polynomial(多項式)」而不是代表「Non-Polynomial(非多項式)。)

NP完全

編輯

要解決P=NP問題,NP完全的概念非常有用。不嚴格的講,NP完全問題是NP類中「最難」的問題,也就是說它們是最可能不屬於P類的。這是因為任何NP中的問題可以在多項式時間內變換成為任何特定NP完全問題的一個特例。例如,旅行推銷員問題的判定問題版本為NP完全。所以NP中的任何問題的任何特例可以在多項式時間內轉換成旅行商問題的一個特例。所以若旅行商問題能證實在P內,則P=NP。旅行商問題是很多這樣的NP完全的問題之一。若任何一個NP完全的問題在P內,則可以推出P=NP。不幸的是,雖然很多重要的問題被證實為NP完全,但卻沒有一個有已知快速的算法。

更難的問題

編輯

雖然是否P=NP還是未知的,在P之外的問題是已經知道存在的。尋找國際象棋圍棋最佳走法(在nn棋盤上)是NP困難的。因為可以證明P≠EXPTIME(指數時間),這些問題位於P之外,所以需要比多項式時間更多的時間。判定皮爾斯伯格算術英語Presburger arithmetic中的命題是否為真的問題更加困難。Fischer和Rabin英語Michael O. Rabin於1974年證明每個決定Presburger命題的真偽性的算法有最少22cn的運行時間,c為某個常數。這裡,n是Presburger命題的長度。因此,該命題已知需要比指數時間更多的運行時間。不可判定問題是更加困難的,例如停機問題,而它們無法在任何給定時間內解決。

P真的容易處理嗎?

編輯

上面所有的討論,假設了P表示「容易」而「不在P中」表示「困難」。這是一個在複雜度理論中常見而且有一定準確性的假設,它在實踐中卻不總是真的,原因包括如下幾點:

  • 它忽略了常數因子。一個需要101000n時間的問題是屬於P的(它是線性時間的),但是事實上完全無法處理。一個需要10-100002n時間的問題不是在P中的(它是指數時間的),但是對於n取值直到幾千時還是很容易處理的。
  • 它忽略了指數的大小。一個時間複雜度n1000屬於P,但是很難對付。已經證明在P中存在需要任意大的指數的問題(參看時間層次定理)。一個時間複雜度2n/1000的問題不屬於P,但對於n直到幾千還是容易應對的。
  • 它只考慮了最壞情況的複雜度。可能現實世界中的有些問題在多數時候可以在時間n中解決,但是很偶爾你會看到需要時間2n的特例。這問題可能有一個多項式的平均時間,但最壞情況是指數式的,所以該問題不屬於P
  • 它只考慮確定性解。可能有一個問題你可以很快解決如果你可以接受出現一點誤差的可能,但是確保正確的答案會難得多。這個問題不會屬於P,雖然事實上它可以很快求解。這實際上是解決屬於NP而還不知道是否屬於P的問題的一個辦法(參看RPBPP)。
  • 新的諸如量子計算機這樣的計算模型,可能可以快速的解決一些尚未知道是否屬於P的問題;但是,沒有一個它們已知能夠解決的問題是NP完全的。不過,必須注意到PNP問題的定義是採用像圖靈機這樣的經典計算模型的術語表述的。所以,即使一個量子計算機算法獲發現能有效解決一個NP完全問題,我們只是有了一個快速解決困難問題的實際方法,而不是數學類PNP相等的證明。

P≠NP的觀點

編輯

多數計算機科學家[誰?]相信PNP[2]。該信念的一個關鍵原因是經過數十年對這些問題的研究,沒人能發現一個NP完全問題的多項式時間算法。而且,人們早在NP完全的概念出現前就開始尋求這些算法(Karp的21個NP完全問題,在最早發現的一批中,有所有著名的已經存在的問題)。進一步,P=NP這樣的結果會導致很多驚人結果,那些結果現在被相信不成立,如NP=反NP和P=PH

也有這樣論證:問題難求解(P)但易驗證(NP),這和我們日常經驗相符。

從另一方面講,某些研究者認為我們過於相信PNP,而應該也去尋找P=NP的證明。例如,2002年有這聲明:[3]

關於證明的難度的結果

編輯

雖然百萬美元的獎金和投入巨大卻沒有實質性結果的大量研究足以顯示該問題很難,但是還有一些形式化的結果證明為什麼該問題可能很難解決。

最常引用的結果之一是設計神諭。假想你有部魔法機器可以解決單一問題,例如「判定某數是否質數」,這魔法機器可以瞬間解決這問題。我們的新問題是,若我們獲允許任意利用這機器,是否存在我們可以在多項式時間內驗證但無法在多項式時間內解決的問題?結果是,依賴於機器能解決的問題,P=NPPNP二者都可以證明。這個結論帶來的後果是,任何可以通過修改神諭來證明該機器的存在性的結果不能解決問題。不幸的是,幾乎所有經典的方法和大部分已知的方法可以這樣修改(我們稱它們在相對化)。

如果這還不算太糟的話,1993年Razborov和Rudich證明的一個結果表明,給定一個特定的可信的假設,在某種意義下「自然」的證明不能解決P=NP問題。[1]頁面存檔備份,存於網際網路檔案館)這表明一些現在似乎最有希望的方法不太可能成功。隨着更多這類定理得到證明,該定理的可能證明方法有越來越多的陷阱要規避。

這實際上也是為什麼NP完全問題有用的原因-若對於NP完全問題存在有一個多項式時間算法,或者沒有這樣的算法,這將能用一種相信不被上述結果排除在外的方法來解決P=NP問題。

多項式時間演算法

編輯

沒人知道多項式時間演算法對於NP完全問題是否存在。但是如果這樣的演算法存在,我們已經知道其中的一些了!例如下面的算法正確地接受了一個NP完全語言,但是沒人知道通常它需要多久執行。它是一個多項式時間演算法當且僅當P=NP

  // 接受NP完全語言的一個算法子集和。
  //
  // 這是一個多項式時間算法當且僅當P=NP。
  //
  // 「多項式時間」表示它在多項式時間內返回「是」,若
  // 結果是「是」,否則永遠運行。
  //
  // 輸入:S = 一個自然數的有限集
  // 輸出:"是"如果某個S的子集加起來等於0。
  //         否則,它永遠運行沒有輸出。
  // 注意:  "程序數P"是你將一個整數P寫為二進制,然後
  //         將位元串考慮為一個程序。
  //         每個可能的程序都可以這樣產生,
  //         雖然多數什麼也不做因為有語法錯誤。
  //         
  FOR N = 1...infinity
      FOR P = 1...N
          以S為輸入運行程序數P N步
          IF程序輸出一個不同的整數的列表
              AND所有整數都在S中
              AND整數的和為0
          THEN
              OUTPUT "是"並 停機

P=NP,則這是一個接受一個NP完全語言的多項式時間算法。「接受」表示它在多項式時間內給出「是」的答案,但允許在答案是「否」的時候永遠運行。

可能我們想要「解決」子集和問題,而不是僅僅「接受」子集和語言。這表示我們想要它總是停機並返回一個「是」或「否」的答案。是否存在任何可能在多項式時間內解決這個問題的算法?沒有人知道。但是如果這樣的算法存在,那麼我們已經知道其中的一些了!只要將上面的算法中的IF語句替換成下面的語句:

          IF程序輸出一個完整的數學證明
              AND證明的每一步合法
              AND結論是S確實有(或者沒有)一個和為0的子集
          THEN
              OUTPUT "是"(如果獲證實,就"不是")並停機

邏輯表述

編輯

P=NP問題可以用邏輯命題的特定類的可表達性的術語來重新表述。所有P中的語言可以用一階邏輯加上最小不動點操作(實際上,這允許了遞歸函數的定義)來表達。類似,NP是可以用存在性二階邏輯來表達—也就是,在關係、函數、和子集上排除了全稱量詞的二階邏輯。多項式等級PH中的語言對應與所有的二階邏輯。這樣,「P是NP的真子集嗎」這樣的問題可以表述為「是否存在性二階邏輯能夠表達帶最小不動點操作的一階邏輯的所不能表達的語言?」

花絮

編輯

普林斯頓大學計算機系樓將二進制代碼表述的「P=NP?」問題刻進頂樓西面的磚頭上。如果證明了P=NP,磚頭可以很方便的換成表示「P=NP!」。[4] [5]

康奈爾大學的Hubert Chen博士提供了這個玩笑式的P不等於NP的證明:[6]

反證法。設P=NP。令y為一個P=NP的證明。證明y可以用一個合格的電腦科學家在多項式時間內驗證,我們認定這樣的科學家的存在性為真,但因為P=NP,該證明y可在多項式時間內由這樣的科學家發現,但是這樣的發現還沒有發生(雖然這樣的科學家試圖發現這樣的一個證明),我們得到矛盾。

註釋

編輯
  1. ^ Wayback Machine(网页存档). web.archive.org. 2005-04-04 [2017-09-05]. (原始內容存檔於2005-04-04). 
  2. ^ P≠NP - 百度学术. xueshu.baidu.com. [2024-05-12]. (原始內容存檔於2024-05-12). 
  3. ^ William I. Gasarch. The P=?NP poll. (PDF). SIGACT News. June 2002, 33 (2): 34–47 [29 December 2008]. doi:10.1145/1052796.1052804. (原始內容存檔 (PDF)於2019-10-27). 
  4. ^ https://www.cs.princeton.edu/general/images/csbricksjpg. [2018-10-04]. (原始內容存檔於2019-02-17).  外部連結存在於|title= (幫助)
  5. ^ https://www.cs.princeton.edu/general/bricks. [2018-10-04]. (原始內容存檔於2017-12-14).  外部連結存在於|title= (幫助)
  6. ^ http://www.cs.cornell.edu/hubes/pnp.htm. [2005-07-15]. (原始內容存檔於2005-09-27).  外部連結存在於|title= (幫助)

參考文獻

編輯
  • Gerhard J. Woeginger. The P-versus-NP page頁面存檔備份,存於網際網路檔案館)。Lists a number of incorrect solutions to the problem.
  • A. S. Fraenkel and D. Lichtenstein, Computing a perfect strategy for n*n chess requires time exponential in n, Proc. 8th Int. Coll. Automata, Languages, and Programming, Springer LNCS 115 (1981) 278-293 and J. Comb. Th. A 31 (1981) 199-214.
  • E. Berlekamp and D. Wolfe, Mathematical Go: Chilling Gets the Last Point, A. K. Peters, 1994. D. Wolfe, Go endgames are hard, MSRI Combinatorial Game Theory Research Worksh., 2000.
  • Neil Immerman。Languages Which Capture Complexity Classes. 15th ACM STOC Symposium, pp.347-354. 1983.

延伸閱讀

編輯

外部連結

編輯

參見

編輯