一串長為M的珠子,珠子的顏色有N種(N<10)。求包含N種顏色的最短連續珠串。
創新互聯建站科技有限公司專業互聯網基礎服務商,為您提供成都二樞服務器租用托管,高防主機,成都IDC機房托管,成都主機托管等互聯網服務。//兩個指針,開始的時候都指向某一個位置,移動前一個指針,直到兩個指針直接包含了所有顏色的珠子。
//此時記下len。
//然后向前移動后面的指針,再調整最前面的指針,直到重新滿足兩個指針間包含了所有的顏色,比較此時的len和之前的len,取最小值。
//如此移動,直到后面的指針回到起始位置。
//時間復雜度是O(N),空間復雜度是O(1)
#include<iostream> using namespace std; void Search(char* src,char* ch) { int varies = 0;//多少種顏色 char* begin = src; memset(ch, 0, sizeof(char) * 256); while (*begin++) { if (ch[*begin - '0']++ == 0) { ++varies; } } //此時varies存儲共有多少種顏色 int MinLength = 0; int curLength = 0; char* prev = src; char* cur = src; int curVaries = 0; char* ret = NULL; memset(ch, 0, sizeof(char) * 256); while (1) { curLength = 0; curVaries = 0; cur = prev; memset(ch, 0, sizeof(char) * 256); while (curVaries != varies) { if (++ch[*cur - '0']==1) curVaries++; ++cur; ++curLength; if (*cur == '\0') cur = src; } if (MinLength == 0 || MinLength > curLength) { MinLength = curLength; ret = prev; } if (MinLength == varies) break;//得到最短的 ++prev; if (*prev =='\0') break; } int flag = 1; int index = 0; for (int i = 0; i < MinLength; ++i) { if (ret[i] == '\0') flag = 0; if (flag == 1) ch[i] = ret[i]; else ch[i] = src[index++]; } ch[MinLength] = '\0'; } void Test1() { char* src = "abbcdabcddddacgd"; char ch[256] = { 0 }; Search(src,ch); cout<<ch<< endl; } //所得結果應該是cgdab
創新互聯www.cdcxhl.cn,專業提供香港、美國云服務器,動態BGP最優骨干路由自動選擇,持續穩定高效的網絡助力業務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統配攻擊溯源,準確進行流量調度,確保服務器高可用性。佳節活動現已開啟,新人活動云服務器買多久送多久。
分享題目:字符串匹配之通配符問題--創新互聯
瀏覽路徑:http://vcdvsql.cn/article40/ggoeo.html
成都網站建設公司_創新互聯,為您提供手機網站建設、云服務器、軟件開發、微信小程序、App設計、外貿網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯