青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

<2006年10月>
24252627282930
1234567
891011121314
15161718192021
22232425262728
2930311234

統(tǒng)計

  • 隨筆 - 44
  • 文章 - 0
  • 評論 - 86
  • 引用 - 0

常用鏈接

留言簿(6)

隨筆分類(31)

隨筆檔案(44)

Mining

最新隨筆

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

Diff 算法
Diff 在Linux下非常有用, 最近在對定向蜘蛛的研究中, 發(fā)現(xiàn)網(wǎng)頁的信息大部分在Diff部分, 所以考慮了Diff的原理.

1. Unix Diff

Linux Diff 的基本原理在文 [ Dynamic Programming | http://www.sbc.su.se/~pjk/molbioinfo2001/dynprog/dynamic.html ] 中介紹的很詳細了.如果一個文件有n行, 則需要對一個n*n的矩陣進行計算以得到最佳匹配.


2. 貪心算法

在[ Windiff原理初探 | http://www.2maomao.com/blog/how-windiff-works-continued-1/ ]中看到一個貪心算法, 感覺在某種情況下還是比較適合的,但是有些情況還是存在一些問題.

貪心算法的基本思路是: 從問題的某一個初始解出發(fā)逐步逼近給定的目標(biāo),以盡可能快的地求得更好的解。當(dāng)達到某算法中的某一步不能再繼續(xù)前進時,算法停止。

首先還是簡化問題:每個行根據(jù)內(nèi)容映射到一個整型值, 這就將整個問題簡化為整形數(shù)組的比較,姑且稱之為Anew和Aold。

程序處理流程簡述:
while (還沒到頭)
{
?? while (還可以繼續(xù)找,還可以更貪心)
?? {
????? 找到下一個匹配的(依次對ANew的元素,查找其在AOld中的位置)
????? if (找的到)
???????? 計算其貪心值,如果當(dāng)前更貪則用這個匹配做當(dāng)前最佳匹配
????? else
???????? break;
?? }
}
輸出剩余的未匹配節(jié)點。

其中“還可以更貪心”是如何判定的呢?

首先定義左臂(leftHand,Anew里面新匹配位置距上一次被采用的匹配的距離),右臂(rightHand,Aold里面新匹配位置距上一次被采用的匹配的距離)。

要找一個目標(biāo),在這里我給定的目標(biāo)是左右平衡情況下的最近匹配。比如一個匹配左臂1,右臂10,另一個匹配是左臂3,右臂3,這時候傾向于選擇后一個匹配。
為了公式化和便于計算,我采用一個簡單的具有這個邏輯的函數(shù):leftHand*leftHand + rightHand*rightHand的值(貪心值)最小。

定義了這個目標(biāo)以后,你會發(fā)現(xiàn)只要左臂過長,lefthand自身的平方超過上個候選匹配的貪心值,則可以停止往下計算了。

然后這個循環(huán)繼續(xù)下去,直到找到所有的匹配,對每兩個匹配之間,如果有內(nèi)容,則表示有Add/Delete/Modify發(fā)生,根據(jù)左臂右臂是否為0可以明顯區(qū)分。

舉個例子:
Anew Aold
1???? 1
2???? 1
3???? 3
2???? 2
4???? 4
首次匹配找到1<-->1,匹配立即停止,因為1*1 + 1*1 = 2,2*2 > 2,所以沒有比較進行下去了.

然后往下找到2<-->2,這時候左臂等于1,右臂等于3,(注意臂長是相對上一次被采用的匹配的),1*1 + 3*3 = 10,當(dāng)前貪心值是10;然后往下找到3<-->3,左臂為2,右臂為2,2*2 + 2*2 = 8,這個匹配優(yōu)于上一個匹配;然后繼續(xù)往下找到2<-->2(左邊第二個2),左臂3,右臂3,3*3本身的平方已經(jīng)超過目前的貪心值8,沒有必要再繼續(xù)往下匹配,這一輪匹配查詢結(jié)束。

這里可以看出采用平方和做貪心算式的好處,很快可以收斂,而且符合“左右平衡”以及“最近匹配”。
后面2和4的分析略去。

但是這個算法存在一個問題,它的算法只針對單行最優(yōu), 而無法實現(xiàn)多行的最優(yōu), 比如
Anew Aold
a??? a
b??? a
c??? b

像上面的兩個文件, Anew:1 匹配 Aold:1, 但是應(yīng)該使 Anew:1 匹配 Aold:2, 這樣子才可以使Anew中序列ab 與 Aold的序列ab匹配.


3. 下一步工作

?* 調(diào)整貪心值計算函數(shù)
?* 貪心算法 + 部分動態(tài)規(guī)劃


posted on 2006-10-08 19:23 泡泡牛 閱讀(4279) 評論(1)  編輯 收藏 引用

評論

# re: Diff 算法[未登錄] 2008-11-14 12:31 Tony

你的那個貪心算法,不如那個動態(tài)規(guī)劃法好用啊
  回復(fù)  更多評論    

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            日韩午夜在线视频| 免费试看一区| 久久综合久久综合九色| 午夜天堂精品久久久久| 亚洲一区图片| 亚洲欧美国产精品桃花| 午夜精品久久久久| 欧美专区在线观看一区| 久久久久久亚洲精品中文字幕| 欧美一区二区三区在线免费观看| 亚洲主播在线| 欧美在线电影| 久久夜色精品国产欧美乱极品| 麻豆久久婷婷| 亚洲日本va午夜在线电影| 夜夜嗨av一区二区三区| 亚洲在线观看视频| 久久青青草综合| 欧美精品一区二区蜜臀亚洲| 欧美日韩亚洲一区三区| 国产欧美一区二区精品性| 亚洲第一黄色| 亚洲视频一起| 久久综合国产精品| 夜夜嗨av一区二区三区中文字幕| 亚洲欧美三级在线| 欧美国产日韩一区二区在线观看| 久久久噜噜噜久久人人看| 国语精品中文字幕| 99re6这里只有精品视频在线观看| 亚洲午夜成aⅴ人片| 久久综合久久久久88| 日韩网站在线观看| 欧美中文字幕不卡| 欧美日韩免费看| 狠狠色丁香久久婷婷综合_中| 亚洲精品一区二区三区蜜桃久| 亚洲欧美日韩精品一区二区| 欧美成人有码| 午夜精品影院| 欧美日韩亚洲高清| 亚洲电影av| 欧美自拍丝袜亚洲| 日韩香蕉视频| 麻豆91精品91久久久的内涵| 国产欧美va欧美不卡在线| 日韩午夜剧场| 欧美激情精品久久久久久免费印度 | 欧美伊人久久久久久久久影院| 免费视频最近日韩| 激情久久影院| 久久阴道视频| 欧美在线国产| 国产偷自视频区视频一区二区| 亚洲一区二区高清视频| 亚洲精品日本| 欧美区日韩区| 夜夜精品视频一区二区| 亚洲电影免费观看高清完整版在线| 午夜在线视频观看日韩17c| 欧美日韩在线综合| 这里只有精品视频在线| 日韩视频免费大全中文字幕| 欧美精品97| 亚洲色图在线视频| 在线亚洲一区观看| 国产精品一香蕉国产线看观看| 午夜日韩在线| 亚洲欧洲av一区二区| 国产日韩在线看片| 老司机凹凸av亚洲导航| 快射av在线播放一区| 亚洲三级视频| 99re热这里只有精品视频| 欧美日韩在线综合| 欧美在线视频二区| 久久久亚洲高清| 亚洲激情六月丁香| 亚洲日本久久| 国产精品永久免费| 久久综合色播五月| 欧美日本高清视频| 亚洲视频中文字幕| 牛人盗摄一区二区三区视频| 韩国三级电影久久久久久| 欧美国产精品中文字幕| 麻豆精品在线观看| 亚洲免费网址| 欧美国产精品| 亚洲每日在线| 亚洲综合二区| 精东粉嫩av免费一区二区三区| 亚洲高清av| 亚洲人永久免费| 国产丝袜一区二区| 亚洲午夜伦理| 美女视频黄 久久| 免费91麻豆精品国产自产在线观看| 国产精品美女在线| 亚洲欧洲一二三| 夜夜夜久久久| 亚洲午夜电影网| 亚洲精品乱码久久久久久| 国产真实久久| 亚洲日本va午夜在线影院| 国产日韩欧美三区| 亚洲精品综合精品自拍| 激情视频一区二区| 亚洲天堂网在线观看| 亚洲精品乱码久久久久久黑人| 午夜精品福利在线观看| 一区二区三区视频在线播放| 欧美一区二区三区播放老司机 | 欧美精品在线观看一区二区| 欧美一区二区黄色| 欧美成人黑人xx视频免费观看| 欧美一区二区高清| 欧美视频三区在线播放| 亚洲国产精品久久久久婷婷884| 国产日韩欧美在线观看| 一区二区精品| 一区二区三区欧美亚洲| 欧美国产精品人人做人人爱| 男人插女人欧美| 国内久久视频| 久久er精品视频| 久久精品国产69国产精品亚洲| 欧美午夜不卡影院在线观看完整版免费| 欧美成人免费在线| 91久久精品国产91久久| 欧美视频日韩视频| 亚洲人成网站在线观看播放| 亚洲区一区二| 欧美成人精品在线播放| 欧美高清你懂得| 亚洲国产免费看| 农夫在线精品视频免费观看| 欧美岛国在线观看| 最新日韩av| 欧美精品v日韩精品v国产精品 | 老色批av在线精品| 国内伊人久久久久久网站视频| 亚洲欧美在线播放| 久久久久国产精品麻豆ai换脸| 国产欧美日韩一级| 久久爱www.| 麻豆91精品| 亚洲黄色性网站| 欧美母乳在线| 一区二区三区日韩精品| 午夜亚洲福利在线老司机| 国产日韩欧美在线一区| 性欧美长视频| 欧美高清视频一二三区| 亚洲理伦电影| 国产精品久久久久久久久免费樱桃 | 欧美在线一二三区| 你懂的视频一区二区| 亚洲三级电影全部在线观看高清| 欧美日本国产| 午夜精品短视频| 欧美成人综合一区| 亚洲无吗在线| 国内精品模特av私拍在线观看| 狂野欧美激情性xxxx| 日韩一级免费| 巨胸喷奶水www久久久免费动漫| 亚洲欧洲日本一区二区三区| 国产精品福利片| 久久精品视频va| 亚洲精品国产精品国自产在线| 亚洲欧美日韩精品综合在线观看| 国内在线观看一区二区三区| 欧美国产精品日韩| 欧美一区激情| 亚洲精品免费观看| 久久久欧美一区二区| 一区二区日韩精品| 在线观看中文字幕不卡| 国产精品欧美一区喷水| 欧美sm重口味系列视频在线观看| 亚洲伊人观看| 亚洲日韩欧美一区二区在线| 久久国产一二区| 中文一区二区| 亚洲欧洲日本专区| 国产一区二区三区无遮挡| 欧美日韩免费高清| 美日韩精品免费| 欧美亚洲尤物久久| 国产精品成人v| 亚洲综合国产激情另类一区| 亚洲一区久久| 91久久久久久久久久久久久| 国产免费成人av| 欧美性猛交一区二区三区精品| 久久综合中文色婷婷| 欧美亚洲日本一区| 在线亚洲观看| 一本不卡影院|