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

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

偶爾來(lái)避難的地方~

  C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  94 隨筆 :: 0 文章 :: 257 評(píng)論 :: 0 Trackbacks
  1 ///@brief 使用空白字符匹配
  2 #define    USE_WHITE_SPACE_MATCH
  3 
  4 /*!
  5 *    @brief 匹配一個(gè)字符串模版
  6 *    @param pszText 需要匹配的字符串
  7 *    @param uTextLen 需要匹配的字符串長(zhǎng)度
  8 *    @param pszTemplateText 需要匹配的模版字符串
  9 *    @param uTemplateTextLen 需要匹配的模版字符串的長(zhǎng)度
 10 *    @param pMatchedLen 返回的完成匹配的字符串長(zhǎng)度
 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     //    沒(méi)有匹配的模版,直接匹配成功
 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                     //    結(jié)尾的*,直接認(rèn)為是匹配所有字符(包括空)
 59                     if( pMatchedLen != NULL )
 60                         *pMatchedLen = uTextLen;
 61                     return true;
 62                 }
 63 
 64                 wchar_t cNextTemplate = pszTemplateText[uTemplateTextPos+1];
 65                 //    跳過(guò)重復(fù)的*
 66                 if( cNextTemplate == '*' )
 67                 {
 68                     ++uTemplateTextPos;
 69                     break;
 70                 }
 71                 //    記錄最后一個(gè)*的出現(xiàn)位置
 72                 if( uLastStarPos != uTemplateTextPos )
 73                     uLastStarPos = uTemplateTextPos;
 74                 //    檢查下一個(gè)模版字符是否匹配
 75 
 76                 //    ?匹配直接跳過(guò)
 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                 //    下一個(gè)字符
 98                 ++uTextPos;
 99             }
100             break;
101         default:
102             if( cTemplate != pszText[uTextPos] )
103             {
104                 //    如果遇到過(guò)*就回退到最后一個(gè)*
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         //    沒(méi)有成功匹配完整個(gè)模版,文字就沒(méi)有了
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 

模版支持三種匹配符號(hào) '*','?','.'
*匹配任意多個(gè)任意字符串
?匹配一個(gè)字符串
.匹配一個(gè)空格
可以通過(guò)注釋掉宏來(lái)禁止匹配空格
達(dá)到的效果和文件系統(tǒng)的文件名匹配差不多


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

雖然他一直在堅(jiān)持自己是在做學(xué)術(shù)研究,也有不少人匿名來(lái)支持他,不過(guò)我覺(jué)得他還是有些態(tài)度問(wèn)題。
總是喜歡在別人的貼上表現(xiàn)自己。做的太過(guò)了就是顯擺了。
從他回帖說(shuō)的那些話,比如“寥寥數(shù)行,瞬間搞定”這些,以及并不完善的代碼看來(lái),他根本就沒(méi)有看過(guò)我的代碼,只是憑字面意思就開(kāi)始貼代碼。
我實(shí)在不清楚他說(shuō)這些話和貼代碼的原因是什么。這些我就不再討論了,我也刪除了他的回復(fù)。
不過(guò)我想說(shuō),如果你一直以這種態(tài)度來(lái)回別人的帖子,那你會(huì)成為一個(gè)令人討厭的人。






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

評(píng)論

# re: 【簡(jiǎn)單的字符串模版匹配】 2011-04-28 15:22 dfdf
支持下!  回復(fù)  更多評(píng)論
  

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

# re: 【簡(jiǎn)單的字符串模版匹配】 2011-04-29 17:10 飯中淹
@臥槽
是的,我確實(shí)是個(gè)菜鳥。
  回復(fù)  更多評(píng)論
  

# re: 【簡(jiǎn)單的字符串模版匹配】 2011-04-29 19:51 Kevin Lynx
@飯中淹
不要跟連名字都不敢留的人一般見(jiàn)識(shí)。  回復(fù)  更多評(píng)論
  

# re: 【簡(jiǎn)單的字符串模版匹配】 2011-07-27 22:21 請(qǐng)輸入你的姓名
1. 有沒(méi)有非UNICODE版本,畢竟多字節(jié)比較麻煩
2. 個(gè)人感覺(jué)沒(méi)必要?jiǎng)h除別人的評(píng)論吧,寥寥幾行的代碼至少也讓別人能看到,言論自由嗎!!!好壞就由他人評(píng)價(jià)不行嗎??  回復(fù)  更多評(píng)論
  

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

//長(zhǎng)度不能超過(guò)FIX_SIZE
if (rule_max >= FIX_SIZE || src_max >= FIX_SIZE)
return false;

// 復(fù)制平移一個(gè)位置
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;
}

// 初始化啟動(dòng)標(biāo)記(new_scan無(wú)啟動(dòng)標(biāo)記)
src_copy[0] = 0;
rule_copy[0] = 0;
old_scan[0] = true; // old_scan 以true開(kāi)始


//1才是開(kāi)始
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];
}

  回復(fù)  更多評(píng)論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            牛牛影视久久网| 免费久久99精品国产| 亚洲精品乱码久久久久久蜜桃麻豆| 精品va天堂亚洲国产| 制服诱惑一区二区| 一区二区电影免费观看| 99re热这里只有精品视频| 亚洲电影第三页| 亚洲蜜桃精久久久久久久| 欧美激情国产精品| 激情欧美丁香| 欧美精品一区在线发布| 美女视频黄a大片欧美| 欧美日韩日日夜夜| 99国产精品99久久久久久| 亚洲精品欧洲| 亚洲日本aⅴ片在线观看香蕉| 久久久午夜电影| 小嫩嫩精品导航| 欧美电影资源| 欧美一区二区三区免费观看视频 | 女生裸体视频一区二区三区| 亚洲欧美日韩在线高清直播| 亚洲毛片在线看| 国产精品一区亚洲| 欧美大片免费| 国产精品v欧美精品v日韩精品| 欧美日韩精品在线视频| 久久亚洲综合网| 欧美激情乱人伦| 亚洲国产视频一区| 亚洲国产日韩综合一区| 亚洲国产成人久久综合| 怡红院精品视频在线观看极品| 另类天堂av| 国产欧美日韩伦理| 国产精品久久久久久av福利软件| 欧美专区第一页| 在线日韩精品视频| 欧美在线欧美在线| 久久亚洲色图| 欧美视频一区二区在线观看| 国产伦精品一区二区三区照片91| 亚洲电影专区| 欧美理论视频| 欧美77777| 久久精品国产69国产精品亚洲 | 一区二区日韩| 亚洲国产日韩欧美在线99 | 麻豆精品91| 国产一区二区三区电影在线观看| 亚洲一区免费网站| 国产伦一区二区三区色一情| 久久不射电影网| 国产一区二区久久| 亚洲午夜电影网| 国产日韩成人精品| 亚洲二区免费| 免费观看一级特黄欧美大片| 美女黄网久久| 欧美国产日韩亚洲一区| 有码中文亚洲精品| 欧美粗暴jizz性欧美20| 国产精品夫妻自拍| 一本色道88久久加勒比精品| 欧美一区二区日韩| 免费观看日韩av| 欧美伊人久久久久久久久影院 | 最新日韩av| 亚洲女同精品视频| 性一交一乱一区二区洋洋av| 久久美女性网| 欧美一区二区国产| 久久精品国产精品亚洲精品| 99这里只有精品| 国产亚洲制服色| 亚洲午夜极品| 欧美成人中文| 小辣椒精品导航| 亚洲精品国产精品国自产在线 | 久久久水蜜桃| 久久本道综合色狠狠五月| 亚洲永久免费精品| 欧美激情一区二区三区成人| 欧美视频在线不卡| 亚洲视频网在线直播| 欧美日韩日日夜夜| 制服丝袜亚洲播放| 欧美色另类天堂2015| 日韩视频精品在线| 久久亚洲春色中文字幕| 欧美主播一区二区三区| 国内精品久久久久影院色| 欧美成人r级一区二区三区| 亚洲综合精品四区| 国产综合久久久久影院| 亚洲最新合集| 一区二区三区波多野结衣在线观看| 国产精品视频免费观看www| 91久久精品一区二区三区| 欧美电影在线观看完整版| 亚洲欧美www| 国产日韩欧美一区二区三区在线观看| 巨乳诱惑日韩免费av| 久久久噜噜噜久久久| 狠久久av成人天堂| 亚洲免费中文| 国产精品推荐精品| 国产精品免费看| 欧美激情免费在线| 夜夜嗨av一区二区三区网站四季av| 久久精品视频免费观看| 亚洲一区在线免费| 国产精品免费电影| 亚洲深夜福利网站| 99精品欧美一区二区蜜桃免费| 99精品99久久久久久宅男| 韩国免费一区| 亚洲人成77777在线观看网| 欧美亚男人的天堂| 最新国产成人在线观看| 在线亚洲美日韩| 亚洲一区二区三区涩| 日韩亚洲精品视频| 亚洲精品久久久久| 国产午夜精品理论片a级大结局| 亚洲一区二区三区免费观看| 欧美寡妇偷汉性猛交| 欧美国产日本| 欧美日韩日本国产亚洲在线| 欧美激情综合色| 欧美国产在线电影| 久久国产成人| 一本一道久久综合狠狠老精东影业| 亚洲精品一区二区网址| 亚洲精品视频免费| 美女精品自拍一二三四| 中日韩高清电影网| 欧美怡红院视频| 亚洲一区二区三区午夜| 久久精品中文字幕一区二区三区| 久久国产综合精品| 欧美日韩国产页| 亚洲一区二区免费在线| 亚洲一区3d动漫同人无遮挡| 午夜精品久久久久久久蜜桃app | 国产精品一区三区| 在线视频日韩| 国产免费成人在线视频| 亚洲一级特黄| 国产欧美一区二区精品仙草咪| 欧美777四色影视在线| 久久男人资源视频| 欧美wwwwww| 国产精品久久久久久亚洲调教 | 欧美一区综合| 激情五月婷婷综合| 国产精品yjizz| 夜夜嗨av一区二区三区| 免费看亚洲片| 亚洲国产精品va在看黑人| 国产欧美日韩精品专区| 久久国产精品亚洲77777| 国产日韩成人精品| 免费观看成人| 午夜精品久久久久久99热| 欧美成人综合| 久久精品30| 99精品热视频只有精品10| 欧美日韩在线三级| 香蕉免费一区二区三区在线观看| 亚洲人成在线观看网站高清| 亚洲一区二区三区在线| 妖精成人www高清在线观看| 欧美国内亚洲| 亚洲宅男天堂在线观看无病毒| 久久精品五月婷婷| 欧美一区国产二区| 久久久久久久综合日本| 亚洲一区欧美激情| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 亚洲欧美网站| 欧美韩国日本一区| 久久久久久网| 免费观看成人www动漫视频| 亚洲国产精品v| 亚洲福利视频在线| 亚洲视频在线二区| 亚洲视频碰碰| 欧美大胆成人| 亚洲激情六月丁香| 亚洲国产精品日韩| 欧美成人性网| 亚洲激情自拍| 久久久久国色av免费观看性色| 欧美午夜精品一区| 国产麻豆视频精品| 国产在线精品一区二区中文| 在线 亚洲欧美在线综合一区| 国产一区二区三区日韩欧美|