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

飯中淹的避難所~~~~~

偶爾來避難的地方~

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  94 隨筆 :: 0 文章 :: 257 評論 :: 0 Trackbacks
  1 ///@brief 使用空白字符匹配
  2 #define    USE_WHITE_SPACE_MATCH
  3 
  4 /*!
  5 *    @brief 匹配一個字符串模版
  6 *    @param pszText 需要匹配的字符串
  7 *    @param uTextLen 需要匹配的字符串長度
  8 *    @param pszTemplateText 需要匹配的模版字符串
  9 *    @param uTemplateTextLen 需要匹配的模版字符串的長度
 10 *    @param pMatchedLen 返回的完成匹配的字符串長度
 11 *    @return 返回是否匹配成功
 12 *    @retval true on 匹配成功
 13 *    @retval false on 匹配失敗
 14 */
 15 bool _MatchTemplate( const wchar_t * pszText, size_t uTextLen, const wchar_t * pszTemplateText, size_t uTemplateTextLen, size_t * pMatchedLen )
 16 {
 17 
 18     size_t uTextPos = 0u, uTemplateTextPos = 0u;
 19     size_t uLastStarPos = ~(size_t)0u;
 20 
 21     //    沒有匹配的模版,直接匹配成功
 22     if( uTemplateTextLen == 0 )
 23     {
 24         if( pMatchedLen != NULL )
 25             *pMatchedLen = uTextPos;
 26         return true;
 27     }
 28     whiletrue )
 29     {
 30         wchar_t cTemplate = pszTemplateText[uTemplateTextPos];
 31         switch( cTemplate )
 32         {
 33 #ifdef    USE_WHITE_SPACE_MATCH
 34         case L'.':
 35             {
 36                 if( pszText[uTextPos] != 0x20 &&
 37                     pszText[uTextPos] != 0x3000 )
 38                 {
 39                     if( pMatchedLen != NULL )
 40                         *pMatchedLen = uTextPos;
 41                     return false;
 42                 }
 43                 ++uTemplateTextPos;
 44                 ++uTextPos;
 45             }
 46             break;
 47 #endif
 48         case L'?':
 49             {
 50                 ++uTemplateTextPos;
 51                 ++uTextPos;
 52             }
 53             break;
 54         case L'*':
 55             {
 56                 if( uTemplateTextPos >= uTemplateTextLen-1 )
 57                 {
 58                     //    結尾的*,直接認為是匹配所有字符(包括空)
 59                     if( pMatchedLen != NULL )
 60                         *pMatchedLen = uTextLen;
 61                     return true;
 62                 }
 63 
 64                 wchar_t cNextTemplate = pszTemplateText[uTemplateTextPos+1];
 65                 //    跳過重復的*
 66                 if( cNextTemplate == '*' )
 67                 {
 68                     ++uTemplateTextPos;
 69                     break;
 70                 }
 71                 //    記錄最后一個*的出現位置
 72                 if( uLastStarPos != uTemplateTextPos )
 73                     uLastStarPos = uTemplateTextPos;
 74                 //    檢查下一個模版字符是否匹配
 75 
 76                 //    ?匹配直接跳過
 77                 if( cNextTemplate == '?' )
 78                 {
 79                     uTemplateTextPos+= 2;
 80                 }
 81 #ifdef    USE_WHITE_SPACE_MATCH
 82                 //    空格匹配
 83                 else if( cNextTemplate == '.' )
 84                 {
 85                     if( pszText[uTextPos] == 0x20 ||
 86                         pszText[uTextPos] == 0x3000 )
 87                     {
 88                         uTemplateTextPos+=2;
 89                     }
 90                 }
 91 #endif
 92                 //    字符匹配
 93                 else if( cNextTemplate == pszText[uTextPos] )
 94                 {
 95                     uTemplateTextPos+=2;
 96                 }
 97                 //    下一個字符
 98                 ++uTextPos;
 99             }
100             break;
101         default:
102             if( cTemplate != pszText[uTextPos] )
103             {
104                 //    如果遇到過*就回退到最后一個*
105                 if( uLastStarPos < uTemplateTextLen )
106                 {
107                     uTemplateTextPos = uLastStarPos;
108                     cTemplate = pszTemplateText[uTemplateTextPos];
109                     ++uTextPos;
110                     break;
111                 }
112                 if( pMatchedLen != NULL )
113                     *pMatchedLen = uTextPos;
114                 return false;
115 
116             }
117             ++uTextPos;
118             ++uTemplateTextPos;
119             break;
120         }
121         //    成功匹配完城所有的
122         if( uTemplateTextPos >= uTemplateTextLen )
123         {
124             break;
125         }
126         //    沒有成功匹配完整個模版,文字就沒有了
127         if( uTextPos >= uTextLen )
128         {
129             if( pMatchedLen != NULL )
130                 *pMatchedLen = uTextPos;
131             return false;
132         }
133     }
134     if( pMatchedLen != NULL )
135         *pMatchedLen = uTextPos;
136     return true;
137 }
138 

模版支持三種匹配符號 '*','?','.'
*匹配任意多個任意字符串
?匹配一個字符串
.匹配一個空格
可以通過注釋掉宏來禁止匹配空格
達到的效果和文件系統的文件名匹配差不多


關于遞歸的方法:
VCZH提供了一個遞歸的解法,并且“寥寥數行,瞬間搞定”。
不過,遞歸會帶來堆棧的問題。
而且他的方法里存在BUG,我就不貼上來了。
據他稱那種方法來自一本 beautiful code的書。此書我沒看過,所以不清楚。
從他的方法本身看,他只能提供是否匹配的一個結果,并且匹配模版和待匹配的字符串必須是0結尾,并且不返回結束匹配時的匹配進度。
并且在處理*的時候,有些許小BUG。

雖然他一直在堅持自己是在做學術研究,也有不少人匿名來支持他,不過我覺得他還是有些態度問題。
總是喜歡在別人的貼上表現自己。做的太過了就是顯擺了。
從他回帖說的那些話,比如“寥寥數行,瞬間搞定”這些,以及并不完善的代碼看來,他根本就沒有看過我的代碼,只是憑字面意思就開始貼代碼。
我實在不清楚他說這些話和貼代碼的原因是什么。這些我就不再討論了,我也刪除了他的回復。
不過我想說,如果你一直以這種態度來回別人的帖子,那你會成為一個令人討厭的人。






posted on 2011-04-27 10:21 飯中淹 閱讀(2472) 評論(6)  編輯 收藏 引用 所屬分類: 數據算法分析

評論

# re: 【簡單的字符串模版匹配】 2011-04-28 15:22 dfdf
支持下!  回復  更多評論
  

# re: 【簡單的字符串模版匹配】 2011-04-29 16:26 臥槽
嗯,菜鳥一般都有你這樣的自卑心理.  回復  更多評論
  

# re: 【簡單的字符串模版匹配】 2011-04-29 17:10 飯中淹
@臥槽
是的,我確實是個菜鳥。
  回復  更多評論
  

# re: 【簡單的字符串模版匹配】 2011-04-29 19:51 Kevin Lynx
@飯中淹
不要跟連名字都不敢留的人一般見識。  回復  更多評論
  

# re: 【簡單的字符串模版匹配】 2011-07-27 22:21 請輸入你的姓名
1. 有沒有非UNICODE版本,畢竟多字節比較麻煩
2. 個人感覺沒必要刪除別人的評論吧,寥寥幾行的代碼至少也讓別人能看到,言論自由嗎!!!好壞就由他人評價不行嗎??  回復  更多評論
  

# re: 【簡單的字符串模版匹配】[未登錄] 2011-08-05 14:04 VK
//和文件名匹配相似,只支持*和?,無遞歸
#define FIX_SIZE 1024
bool _match_fix_size(const wchar_t* src, int srcLen, const wchar_t* rule, int ruleLen)
{
// 聲明掃描線并確定新長度
bool old_scan[FIX_SIZE + 1];
bool new_scan[FIX_SIZE + 1];
const int rule_max = ruleLen + 1;
const int src_max = srcLen + 1;

//長度不能超過FIX_SIZE
if (rule_max >= FIX_SIZE || src_max >= FIX_SIZE)
return false;

// 復制平移一個位置
wchar_t src_copy[FIX_SIZE + 1];
wchar_t rule_copy[FIX_SIZE + 1];
memcpy(&src_copy[1], src, (srcLen + 1) * sizeof(wchar_t));
memcpy(&rule_copy[1], rule, (ruleLen + 1) * sizeof(wchar_t));

//初始化掃描線
for(int i = 0; i < src_max + 1; ++i)
{
new_scan[i] = false;
old_scan[i] = false;
}

// 初始化啟動標記(new_scan無啟動標記)
src_copy[0] = 0;
rule_copy[0] = 0;
old_scan[0] = true; // old_scan 以true開始


//1才是開始
for(int i = 1; i < rule_max + 1; ++i)
{
for(int j = 1; j < src_max + 1; ++j)
{
new_scan[j] = false;
if(rule_copy[i - 1] == src_copy[j - 1] && old_scan[j - 1])
new_scan[j] = true;
if(rule_copy[i - 1] == L'?' && old_scan[j - 1])
new_scan[j] = true;

if(rule_copy[i - 1] == L'*')
{
if(new_scan[j - 1])
new_scan[j] = true;
if(old_scan[j])
new_scan[j] = true;
}
}
for(int j = 0; j < src_max + 1; ++j)
old_scan[j] = new_scan[j];
}
return new_scan[src_max];
}

  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美成人三级在线| 久久精品主播| 国产精品xnxxcom| 亚洲免费在线视频一区 二区| 亚洲免费福利视频| 国产精品腿扒开做爽爽爽挤奶网站 | 久久理论片午夜琪琪电影网| 久久久久成人精品| 亚洲精品国偷自产在线99热| 99精品热6080yy久久 | 免费观看在线综合| 亚洲图片激情小说| 久久成人精品电影| 亚洲精品美女久久久久| 亚洲天堂男人| 尤物网精品视频| 一本色道久久88精品综合| 国产欧美一区二区色老头| 欧美大片第1页| 国产精品亚洲片夜色在线| 欧美aⅴ99久久黑人专区| 欧美日本不卡高清| 久久久久久自在自线| 欧美日韩国产123| 久久亚洲捆绑美女| 欧美性色aⅴ视频一区日韩精品| 久久亚洲免费| 国产精品一区二区三区久久久| 另类av导航| 国产精品香蕉在线观看| 亚洲国产免费| 好吊一区二区三区| 亚洲自啪免费| 亚洲桃色在线一区| 欧美r片在线| 久久亚洲精品一区二区| 欧美在线不卡| 91久久综合| 亚洲一级网站| 宅男噜噜噜66国产日韩在线观看| 久久精品国产一区二区三区免费看| 亚洲一区二区三区高清| 免费观看久久久4p| 麻豆91精品| 黑丝一区二区| 欧美综合国产| 久久精品国产久精国产一老狼| 欧美日韩中文字幕在线| 亚洲人成网在线播放| 亚洲国产欧美日韩精品| 久久精品国产亚洲高清剧情介绍| 欧美一区二区黄色| 国产精品久在线观看| 一本色道久久综合亚洲精品婷婷| 亚洲精品一区二区三区四区高清 | 一区二区三区久久久| 夜夜嗨av色一区二区不卡| 蘑菇福利视频一区播放| 欧美福利视频在线| 亚洲高清视频在线观看| 久久伊人免费视频| 蜜臀av性久久久久蜜臀aⅴ| 好吊一区二区三区| 玖玖玖国产精品| 欧美高清一区二区| 亚洲三级性片| 欧美日韩爆操| 亚洲午夜精品国产| 欧美专区一区二区三区| 国产在线精品成人一区二区三区| 亚欧美中日韩视频| 美日韩精品免费| 最新亚洲电影| 欧美视频成人| 亚洲欧美文学| 欧美不卡在线视频| 一区二区成人精品| 国产精品久久久一本精品| 午夜精品久久久久久久99樱桃 | 欧美国产欧美综合 | 亚洲伦理精品| 性欧美大战久久久久久久久| 国产一区二区剧情av在线| 久久久精品日韩| 亚洲人体1000| 久久久777| 亚洲精选国产| 国产精品自拍一区| 免费成人av在线看| 一区二区三区精密机械公司| 久久免费视频一区| 一本一本久久a久久精品综合妖精| 国产精品久久国产愉拍 | 午夜精品亚洲| 亚洲第一精品福利| 欧美有码视频| 好看的亚洲午夜视频在线| 久久久久在线| 亚洲天堂偷拍| 一区在线播放视频| 欧美日韩中文字幕精品| 久久九九全国免费精品观看| 亚洲美女网站| 欧美jizz19hd性欧美| 午夜精品久久久久影视| 亚洲大胆人体视频| 国产精品一区二区欧美| 欧美日韩国产精品成人| 久久精品亚洲一区| 亚洲一区在线视频| 亚洲区一区二| 美女福利精品视频| 欧美在线播放一区| 一区二区三区四区五区在线| 在线视频观看日韩| 国产欧美精品一区aⅴ影院| 欧美日韩成人在线观看| 久久理论片午夜琪琪电影网| 午夜精品成人在线| 一本色道久久综合亚洲91| 亚洲国产精品一区二区久| 另类尿喷潮videofree| 欧美一区永久视频免费观看| 亚洲视频综合在线| 日韩视频精品| 亚洲精品乱码久久久久久日本蜜臀| 国产亚洲午夜| 国产日韩欧美在线看| 国产精品视频你懂的| 欧美亚洲成人网| 欧美日韩中文| 欧美日韩亚洲综合| 欧美人与禽猛交乱配| 欧美精品免费在线| 欧美全黄视频| 国产精品第十页| 国产精品久久激情| 国产农村妇女精品一区二区| 国产精品丝袜xxxxxxx| 国产精品永久入口久久久| 国产精品久久久爽爽爽麻豆色哟哟| 欧美特黄一级大片| 国产精品拍天天在线| 国产老女人精品毛片久久| 国产精品国产三级国产专播精品人 | 亚洲电影免费观看高清完整版在线观看 | 欧美国产一区二区| 欧美护士18xxxxhd| 亚洲精品日韩在线| 一区二区三区**美女毛片 | 欧美激情精品| 亚洲精品日韩综合观看成人91| 日韩午夜精品| 亚洲欧美综合网| 久久久久久九九九九| 美女精品自拍一二三四| 欧美日韩国产免费| 国产精品欧美久久| 极品尤物一区二区三区| 亚洲国产日韩欧美综合久久 | 国产欧美日韩综合一区在线观看 | 久久婷婷久久一区二区三区| 久久一区二区三区国产精品| 欧美a级大片| 欧美午夜性色大片在线观看| 国产欧美日韩在线| 亚洲国产精品美女| 亚洲在线观看免费视频| 久久精品成人一区二区三区| 欧美成在线观看| 亚洲视频在线视频| 久久综合图片| 国产精品一区2区| 亚洲国产高清aⅴ视频| 亚洲在线视频观看| 牛牛精品成人免费视频| 亚洲天堂av综合网| 久久先锋资源| 国产欧美日韩一区二区三区在线| 91久久在线视频| 久久久久久久性| 亚洲人成免费| 久久久久欧美精品| 国产精品乱码一区二三区小蝌蚪| 亚洲大片av| 久久精品电影| 一区二区欧美激情| 欧美电影电视剧在线观看| 国产三级欧美三级| 99在线热播精品免费99热| 久久婷婷国产麻豆91天堂| 亚洲视频图片小说| 欧美激情片在线观看| 极品少妇一区二区三区| 小处雏高清一区二区三区 | 99在线精品观看| 欧美福利网址| 亚洲激情av| 免费看精品久久片| 欧美在线黄色|