Social Icons

twitterfacebookgoogle plusrss feedemail

3/14/2010

資料結構-Knuth,Morris,Pratt的字串樣式比對演算法


  (本文章於2010.03.21PM11:16分第二次更新)
  
這是趙老師要我們寫的第二份作業          
我花了蠻久的時間去做它的

因為還沒有老師教作業的截止日期
所以source code我先鎖上
等時間到了會自動打開

程式執行時的圖示:




【程式碼】:
以下內容已經經過作者加密,請輸入正確密碼才可觀看。
]ÙL!39!!0!!0!-³ôs=ÕrfnV9-÷À£íÊDîÓë*6L-»þ!45!ìÛý]¥NöN¹Û-Ìeº+ÊÑ²ëjô-ù·×ûGÒÉNìZÂÐä-µ^<ç\ú¨e©ù&Y-NsµêrÆ¤ãX!9!-Ã´(f!9!!45!¡õJÚî´{-íÊª/ß)Pàl-XÑ/Qi%¿諳嬭#1ä嬄丰斉-鄕&Çù+ÎnQ!9!å=!0!\T-Àk¤h¼8v=QZ¼Q-P»誢宣扅较儢皃寍仙施醍©;-¹y,vÿ{PÔ6Á¬åü¢-õ%2·Æ¯½÷¹-ÿ°íHD®­î/n½-.¯v^Ýë¨皺対井樃弻毌峬濆-筇氬0wcõRNµ\ðM-Áï,º\Í¨«q!33!^xÎ-ä9EÿV?9¬孍亼櫻-弸殣尸ß毺層揎裨!34!ä¾§Ö!10!¸-.Ãj°T|þ¯¢­¥h-@Ç誉篱橖徔皠妭斲冉徒S-<BhÈ`!10!ÿçÎ-þh@7>ùß¾ª-aÑõ:Æ%++!11!;N¢Y-¾ñwÕªÃÞóù[B!0!Â -×賦斡宛举!12!\HD-üD.!45!!13!ºöÚjbïøä-¶¤éxóß0Ò¤撓屵家乆>-!45!6¶Jq!160!¹j¤r4ÿ´-`ý孓旎ò!160!È嬮乣-P*FT±ðªÞz4SaþM-´ök寍旱坒笇廊僑寄»®0H-²çñô掑裨孳兰皸宾君ÊIÓé-Ý=ô#Ò!12!<¦LòD-諥笧坥笰廸僖寱ÞTî¨1ùßÖ-rºSºÕXi¨諹笊垌筕庵裫-儨獖Ä5:ñsF7ûÁ,-©ò詵箖兠獌殭攍ÿ!10!´ìoÔ搧經-寥冫瘝嬻呶¨v!39!T$Ü- [rÿõet孖厈辷兎寱-享癯僦斴Ó>ÏÄû#3Ñ!9!J-F¤h誁篍圻筅帍傼存§çG-9ÌqÃÙ誃筊垸篼-廅袧儂獻o5!33!0(¯~bÜ>!11!-!160!読箃儯猀殯旫An³NG-ÇUD»´øÐ2xê¬Ç-?üÖ!9!Ñp<N[Ôm-_­¦¶ïU^£Z<Â-Ì¿Ê孉敝待gñ诪卂皰宵凐Ý-ííÅ/ßòQÉ}Z¬dbç-p$<誡篓昵锢嶒örÎÚV-³!11!XÝëÇûnÄ©Æ7-ÒD¿Wâm}BY-æ3o(¤ºÊê訾边儖褧擙-岁瘣寛与ß杺奥辴儽%倝孕:Þ-´ãé0½uÑHq#Äq-!12!²¹ç&ÁÌluÎâè-~¢]UÃ)j2üWüìÃ-Ð疸侂攙羿戞輑军癞孋仚敢L±-µÇÈ.L«ç!12!ÕÒv%-ÛV²áZÇ¨!39!$!9!³5-Ôe!11!gm5,ÊH-Ó+³»°5yíÄ!0!¯Ý!11!É-wÊu½üyã¢¶/ØW-÷ô/3BcCâðgjÒ°-ìX!39!·¿Ü,<õü-5Ãü>7RìkuÒÁ-!12!áÔÂÒC±¢¯+¢SÒKt-#5!0!(k6#ÊÉ9b§SÔ-Ñ(¢J岟刊馡皅穳闥宖兾-»×ö÷È_r¿:õðs-¾²¸ ´nQø!33!Ý[-2Ô²ôäÛ;â\0Î÷¢l-$§ì÷`ÌJÿ´V>-\÷¦×ýó戕刽捜袪寭孌乓íL-¨ýÚ8Xr9/óþ³-±?R# 8®mZÌ!33!!33!¸闎夑-誮智7Cýg´»lCÜHy-¾Å~É¦!11!õ詾箨檻必瘈妾旅-冠弥!33!¡Å/ `Ekbÿa-¸qÂ£!9!L=My¡±锉姾-倀寉么欫局rl%uê¿wD®-ïGkÜ^Lvf Xû{-¡!33!®g¥V}!160!çµR-ÝjÔ!11!ôðößï1½-A9Ü¥JÂ絨柊詄暮LmSú-!34!,GzÆ[¤üÉfè¥U:-$¦!45!¹R$ÔeÞû}恞摖-絚皡Ö繃凒凙玧¦ó殱É<æ-µÒ§ºz!12!£¬gå]ºÊ-ÖÆ­Ñ+þÌI¦纮冽舂乊ñ%-禌_]Z3ì|-Üò¥!39!d¥r!10!<ã·èÙõ-öN0àÄ=µõ04µÝþ-5èR7PR|;ýÐ:-ÊÒ¿sÙ}ûï#HË½¦閽-锤W橩桰t]BÃÔ!9!÷-[!12!5P²$s&÷eÒ-ynS½»Þ5wpC-,m×ÐÒßÑÿ2Zö#6¨Á-R>afzL!34!ooJêc;ðY-SÓû!13!ë¸d<Öô®û÷¯þ-ð¬s¡3¥>êÎËÓ|@þ-¤×¬S*½:!33!ú<ÐÊ%ë癈-孭並橑忥欒屝澈筠氈)É*I#d-!33!å(«MáÐ¸Á!34!1nÅ-êüÛòÕR!34!ñ®!39!Í-6múL%ò!160!¯­_]Z­-ñíå´o!12!m³^¢d(]-ËÔ0¢»¶ÓÜ°ÛÊÃ5-oßËXí©ÎÍdb­-PÙ1ó­¼S_3!160!)òíÈ-»S:ÁgDáKñQ,â¬-pª!12!Z£ÍkB¶[-J½³瀸挚衅瘑¶XFú碙ﾛ甒-郻瀚勥攀垷筘庭衵拷劦賅既Ýø4-./î¦méîÆbsÎyl-G<03`GLN!39!!12!3-Úé(Obdt3-\×ÖJåÛiÅöf°OÒ-ð^ýîÉ6%òr_-Û{¾Hy#¿!160!!11!-Q4ÞºE±²z²-o²¥t>cSts/@!10!-V*=#\bS´*!33!Ïñ¾-!33!êËâ@@X§-[Lºx!13!kÂ2FSþT½-_ÚÍ!12!¼9£!33!{Ú-æ!12!uèÖÿë<Ý5Ê-W¾8ñôlzï­ß[kOç7-*º]âmóÍªÕ¾¾ô-þFvÌkæ#!33!¨!12!âÇÃ-yU¥Ì!10!p(Æ9]¨b-\©ýfJ2SËJªÑ-¯­l!12!Þè訝筣晛筦幬僜寻ÒSÕ-JíÞ`+|Éü¬ª]±-?8戲劚櫠栝专)Ó寏丷ￚ-圮AQ厊奣碑櫺棡价癗笛l;倮寑-ﾓ篑Ò袵¶È.C!12!mD¿-Z|¥»ê@9@!11!\ãh¸-çõ|&p O¶s8q¤-x÷©劗甒拊勰覈摲岇瘓宴丸瘚剆-瘇孵旌艹剹勥执剦瘢,s宨旣倍遌-等àù*~¾TÆÖ夵榐岞-卬亾絼疠扐剩圀綢領仌热襸癇欪葿Û-\ÊjtÚ):¯.å!13!/}-X§çØ6AîÐîü!160!ôD-6guÀ£a{!12!`2¤/HU-&ê¬2]2!45!~·!11!{!33!:-:³ìª`õá,ö6&è-WGIX*:WbÐ²r-þM8¥cóéûúúé#!13!ëL-¡`Æ8¬ûgrÐ<(Sù-jOwûé¡}!13!*¥¡_Ù-Óäh°8¾!13!ÈekÛðÅq-!10!ÌY垬素頶亮炦見癸筗¸^毂萃-仯得!12!o¦óX!10!學攊妱枝殘~Ì-v杄夾孎攥適觽奂曆ﾮ劅颌礓毶衠詒-恊¼Ê*®*oxIs-o:¨%QÞ/gÂFÐ65-ö!39!^M*ÁL«!45!VÁ-_çnör!160!垍綅飱乢灍覽皸笕ò-å殺萷ç;²}!11!Õ卐举-刔卌减姇絕毚萯支®zB¡XiV-ËÂ~É¶áØ\Ãç2×ë-|<¬·兆珟庙歧©3¹/è¶-Ù[døJQ!45!H¬É/-åIÕß4VgMX¨[Æ;´-,ÎË T6´s¯Ø7):-!34!Ù&P_oäÜ>JÓpË´-}³Pv=S×£Úûèn#)!10!-X»Ý¦Ií¢ìRñÙ-²©ò6JSøÆN2Éð`-êpDïïU7)ç[m-Þý]5eÄ\â]ñ,òð-9º¡!10!Ì(im¸}v-]ôv,!45!ù!0!Oâäc}!9!ÅQ- âÉhÊô!11!JâõTDê«-%=gXbb_¢0ØZ,e-£!45!Y`²P;RLy=-Ánñ8qú2Öñ!0!H->.é)âï÷@tÎ2!12!`癐-宂丱樎彛歖峐漰箴沭XvH<4Y-Ý÷¬ùNtNBÀ}-LÚ¤ÖGÑr=[9õJÖd-×µ¼¤eÃbN2<f-Xàø°£¯ßxuÓX§!0!Ïß-óåÔ¦û¼:ÓÙÅs-4â¸ÕMhGábBüô-!34!7¹pøµ©¢·6-¹æP(LÐÚÊ!12!!39!6!160!s-$± xTUåºLdÍ;Ã|y-|üÎ31f瀼捽裾皧´V-×磪￼畗选灎勭攓埝笙庣蠍抬劋-谯旱ÓBvªæíì¶!45!®fÐ-ùê!45!íÈÊúzÿ¬`-f!10!u´þ¥<,£fT6-õ4´ Ô)®ÃÉ-Ùs!0!ÝdeVaÞPX-úé.ù3{mR)P¤7-tÞý²ÞF`!33!¶îS8bk9-ÃÐ]··Ü\äæ!10!-µhÚ>!10!¶ïùãäÐ±-#Mï>×sº1þüâ-}§ÿ]Ö¨W3ü$9-M]P·¢VhZ!160!Æul½-!160!AFîÀ&d]ÇW¡¶-BôêÐþ×7Ù  »2Lä-Ð¶jk»¼U!0!{°*ÿÑ-&lÅ¯úwË³#éæ¨-Èc[ËK/äÙ=nnòÑ-Y©ÿ=誣笚暨篏庈傿孭g-Á×*Wº¼!160!½ û.½ÄÑ -üZJËwÉDtØl®Õ-孾旅侢攻幏字劦®I¬{ú仹-Ô1ÑÇßÓq!13!¡=W7Ö-冁珴帔殄Éô÷·ØeÐ~.U-µ}1í6 ó,¨D)ÐËPí-í Wái{s-äÌGw%ï.Y+å!34!n8¢Ú-õÀ¼7Ý?4ó>Å-û!33!2jÅ<bãó®ÍNöÿé-z[âÙ<!34!*ßt?N2å-úvír³Ð3eñÒ¬ R-=ª­öf»<Ï!12!!34! -¼!12!.fLU!45!!33!­n-z!11!$5#ÛÌft;Hå«8n-X%ðÐ!13!IaÅ«P½]oV-3ê|jÆ£j^ï}]-!33!SQ½¶#ª¡¼/Å-T¨©O4ÂmÿiÂÖ-)許笪檳彤盐奰斍冶弪¶GEFÙ-$ÕPd3ßÈrÐGÑÈÄm-ÓþªIfïËÐð6-=ï»=Ä¦Ï¬ÒÏ½CqOk-!0!J/ãüÐÊýÞãKæÞá2-ñ­¸&:×ê\hó!33!-3ÓlÈ÷P1!9!gÛp//-ák{H*U¸\yÎedM-áÒ$H8º!10!!13!!160!¾dmæ-~`ÚÎa&äöâ¢ùóÃÆò-TJèådjRëàP6-!0!O·£QÙaè!12!!0!.§!34!-(Ë!33!ºq×²ÌÈØ¤¹¾Â-Üï:c!0!â¼­±Ñ(- aK:ý§,HP¡E¢-ÐÖê]Â!45!åfÜ÷ª|÷ø+-qù®õM+éy>xåw9¸-¼eQöí~O ¥-»±Þ¹iÊ»(T

以下內容已經經過作者加密,請輸入正確密碼才可觀看。
上面程式碼
我是在Visual c++上跑的
DevC++我沒跑過,請自己嘗試一下
另外還需要以下這個東西搭配使用
請下載玩跟你的程式檔放在一起,不然的話請將程式碼中路徑更改一下

htm瀏覽圖示


htm原始碼圖示

htm檔案下載


如果發現文章有錯誤,歡迎留言告知謝謝指教
內容為原創物件,未經同意請勿轉載

6 則留言:

  1. 不好意思,可以麻煩跟妳要一下原始程式碼嗎???
    我是別校的,最近也有類似的作業,想研究看看~
    謝謝︿︿不方便公開可以直接寄給我沒關係,拜託~
    arou65271@hotmail.com
    再次感謝~

    回覆刪除
  2. 這個作業只是將課本上面的程式碼打上VISUAL C++或者DEVC ++上面,基本上就會執行出來了,我只是再把它加上幾行程式碼,測試一下他搜尋的時間...等而已

    如果你學過C那麼應該是不需要跟我要,因為好像沒必要...。

    如果你真的很想要,但你想不出該怎麼下手,我可以給妳我自己做的程式碼,不過你必須讓我了解到你在這題下了多少功夫?與你寫C的程式是?你會用逐步執行麼?
    (主要是我最近看到不少人跟我要答案都是拿來抄作業,這違反了我的本意...)

    回覆刪除
  3. 您好,我只知道KMP的演算法概念,但是寫成程式我就卡住了~
    例如:本文S=oxoxxoxo,P=xoxo,失敗函數是-1 -1 0 1
    一開始先比較前面4個~等於比4次,然後在第4個位置錯誤~
    所以P就移到1的位置,也就是本文的第2個開始比~
    為什麼呢?因為失敗函數告訴我們在0 1的時候是一樣的,不需要重新比較~
    然後做第2次開始比對時,只需要從剛剛錯誤的地方開始比,因為失敗函數告訴我們前面一定是一樣的~......................
    就這樣一直比下去~最後就可以找出答案~
    考試我會,但是打成程式我就真的不知道該怎麼下手了~
    而且老師又要我們程式可以算出比較的次數~~"更是令我頭疼~
    我程式的開發環境是Dev-C++~
    逐步執行是??先輸入檔名然後打字搜尋的意思嗎?
    不好意思,打擾了,阿添~

    回覆刪除
  4. 作者已經移除這則留言。

    回覆刪除
  5. 逐步執行的意思是可以讓程式一行一行執行程式碼,這樣就可以看到一些參數的變化,比較容易解決程式的一些BUG,建議你使用VISUAL C來執行

    請收信

    回覆刪除
  6. 好︿︿謝謝!!!

    回覆刪除

俗話說
凡走過必留下痕跡,凡住過必留下鄰居
凡爬過必留下樓梯,凡來過必留下IP
看過文章之後歡迎留下您寶貴的意見喔!

 
 
无觅相关文章插件,迅速提升网站流量