|
本帖最后由 喜欢喝冰茶 于 2013-10-6 20:40 编辑 ) q7 d) S* @5 @3 i: A
如果两个字符串是这个样子
, l' h% r+ |0 m0 Q& U: h4 F" _
* M# @ _* J- \) F+ istring1: AAAAAATTTTCCCCCGGGTTTTAAAACCCCCCGG$ H; X) K/ d t$ N# E- W
string2: TTAAA
7 n* u8 A7 P. [6 Z' S% |4 G& }
( \. }' c: e) o, K当然要省很多时间,因为不需要对string1一个一个比了!!!
6 v3 F' [7 \' o8 I7 [' r, O/ _" c2 Q! J
string1可以写成:
0 V; @% `# @% ]1 o5 p5 v7 W长度 字符 起始位置8 P: O/ q) W) V. [! D1 U. t
6 A 1: A2 r1 K! a- J& W/ a0 s; G
4 T 73 c( [ W5 U1 I" T8 G( ]: R2 h
5 C 11% S% M9 W! T) O: d; H6 C
3 G 16* m/ P) U% e- W8 K1 ]: {& v( X
4 T 19
. Y, }0 t* S' V; D3 i; @: @......" Z5 m7 B0 U6 A' \+ ?: j2 M
, @0 Y; y, F4 J所以当用string2去比的时候,一开始根本就不用考虑字符为A,G,C的行,因为string2开始是T。因此在这个例子中,不需要去检查string1的每个位置,而是非常有限的几个位置,所以可以省很多时间。
# |7 W( |9 s! T# D7 O. |! P6 T& t4 Y( j
那么如果存在一种这样的转换方法能够将主贴里的字符串转化成这种,势必会省很多时间。有这样一种方法吗?哪里去找?% Z/ P: I7 _5 `* y' q. Z" o
: Q0 y3 `- [3 _1 i, L如果你是有心人,你觉得这个东西最常用在哪里?
; \" c$ i3 u. @! `' f0 K) Q1 Z
" b% d: Q% B2 B7 c对了,文件压缩。
1 U$ [( F) Y: W& T2 r
) Y8 z$ y5 y/ P& w事实上,真正的解决方法就是借鉴了最早用于文件压缩的一种算法,称为Burrows-Wheeler Transform,又称block-sorting compression。这是当年在DEC工作的Michael Burrows和David Wheeler发明的,所以以他们的名字命名,bzip2的压缩文件就是基于该算法的。它的转换其实很简单,如果感兴趣大家可以google/wiki(wikipedia上很详细的操作细节)上去看细节,但简单的来说,就是把一个字符串头围相接,不停的移动一位,然后排序,最后取出最后一列就行了。Burrows-Wheeler Transform的特性就是转换后的字符串相对于原始字符串含有大量的重复字符片段,所以就可以使得我们的问题变的相对快捷。 + ^' A8 {, t3 P5 ?: D( ]4 G. P
" n4 ]6 O9 Z* S, F" }% L1 e那么是否就十全十美,万事大吉了呢?这个需要从实际的具体需求来看。
# X( |' o; z5 x) E: u$ t( S- K
, ~2 d% x9 S1 e0 M: [) C2 o2 t3 H扛吧,没什么好说的。
) ^0 x8 a U! d& n7 ]
% U2 q& [' @: \3 r1 X1 b. O' H |
|