算法-笔记2
fast and slow
data:image/s3,"s3://crabby-images/5bae2/5bae207d939ba6d140a0234d3b3b2fe81bff99c0" alt=""
data:image/s3,"s3://crabby-images/510e7/510e79362a2fa8df3fdd0b6244031f314158070c" alt=""
data:image/s3,"s3://crabby-images/496ec/496ecdff441e810bd8c362dca0794eeefe02563b" alt=""
n! —> singly
- 2^n <= n <= 2^n^2
data:image/s3,"s3://crabby-images/8ac6f/8ac6ff8b2fb62c19965be18a80bdcdf517e3955d" alt=""
Ackermann Function
用来描述递归时间复杂度的方程。
data:image/s3,"s3://crabby-images/4af32/4af32b9941d90819dc02077e303b3d025aec59ae" alt=""
k-fold就是在表示递归,下图描述的更加直观。
data:image/s3,"s3://crabby-images/10259/10259a1887897bec10a4dff5f4c140bea97e0baf" alt=""
注意A3是大于等于,要推到A2才能算出精确值
data:image/s3,"s3://crabby-images/81ea5/81ea59adbe588aed4bc589806aaf8236672d9daa" alt=""
上面的推导过程
data:image/s3,"s3://crabby-images/61df2/61df2412a1dc72bd63272a88d5a271fdfa9e0bdf" alt=""
String
The Pattern Matching Problem
找子字符串
Example 23.1: Suppose we are given the text string
T = “abacaabaccabacabaabb”
and the pattern string P = “abacab”
Then P is a substring of T . Namely, P = T [10..15].
Σ : alphabet
Brute-Force Pattern Matching
暴力遍解 也叫 naive algorithm
Running time O(T*P)
T P 一个substring 一个 string
Rabin-Karp algorithm
先check substring的numbers 再check它是否匹配。
Worst-case Running time O(T*P)
O(n+m+m(n/q))
- q: modulo (always prime)
The Boyer-Moore Algorithm
相比于暴力遍解,只需要加两个启发式。
Looking-Glass Heuristic: 当第一个字节匹配,我们也同时检测最后一个substring是否匹配。
Character-Jump Heuristic: 如果string中有一个字符substring都不存在,直接跳到这个字符串后面。
Worst-Case Analysis of the Boyer-Moore Algorithm
The worst-case running time of the BM algorithm is O(nm + |Σ|). Namely, the computation of the last function takes time O(m + |Σ|) and the actual search for the pattern takes O(nm) time in the worst case, the same as the brute-force algorithm. An example of a text-pattern pair that achieves the worst case is
data:image/s3,"s3://crabby-images/ce4af/ce4af7d52f307f5b1dd998a61fc7213bb03e8fd9" alt=""
这个方法的shift不是很好。所以有下面方法。
Knuth-Morris-Pratt Algorithm
KMP 是线性复杂度。
longest prefix of the good prefix is also a proper suffix of the good prefix 。
增添回溯的Boyer-Moore Algorithm。不像之前一个个字符的判断。而类似于贪婪,检测substring和string的匹配关系直到遇到不匹配的字符。通过咨询失败函数来判断新的索引。
data:image/s3,"s3://crabby-images/e4ed8/e4ed8de355bd904e3d1b9cb7d58d2cbd4177df4e" alt=""
compute π:
Using a similar reasoning, the running time of compute-π(P)
is O(|P|).
1 |
|
remove unnecessary shifts
data:image/s3,"s3://crabby-images/dd9dd/dd9dd4b9dffd2f1c8668347e74acab37d3c4f19a" alt=""
better:
1 |
|
线性复杂度的原因是在循环之中不是 i 就是i+j increases。
The running time of KMP(T,P) (ignoring the construction of π is O(|T|).