程序员面试100题之十四:强大的和谐
生活随笔
收集整理的這篇文章主要介紹了
程序员面试100题之十四:强大的和谐
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
實現一個挺高級的字符匹配算法:
給一串很長字符串,要求找到符合要求的字符串,例如目的串:123
1******3***2 ,12*****3 這些都要找出來,其實就是類似一些和諧系統。。。。。
給一串很長字符串,要求找到符合要求的字符串,例如目的串:123
1******3***2 ,12*****3 這些都要找出來,其實就是類似一些和諧系統。。。。。
?????? 這題的真正意思就是,給你一個目標串,如“123”,只要一個字符串里面同時包含1、2和3,那么這個字符串就匹配了。系統越和諧,說明錯殺的可能行也就越大。加入目標串的長度為m,模式串的長度為n,我們很容易想到O(mn)的算法,就是兩遍for循環搞定。那么有沒有更快的方法呢?
?????? 我們考慮問題的時候,如果想時間變得快,有一種方法就叫做“空間換時間”。哈希表是一種比較復雜的數據結構。由于比較復雜,STL中沒有實現哈希表,因此需要我們自己實現一個。但由于本題的特殊性,我們只需要一個非常簡單的哈希表就能滿足要求。由于字符(char)是一個長度為8的數據類型,因此總共有可能256 種可能。于是我們創建一個長度為256的數組,每個字母根據其ASCII碼值作為數組的下標對應數組的對應項,而數組中存儲的0、1對應每個字符是否出現。這樣我們就創建了一個大小為256,以字符ASCII碼為鍵值的哈希表。(并不僅限于英文字符,所以這里要考慮256種可能)。
?????? 知道了這點,我們可以構建一個數組來統計模式串中某個字符是否出現,然后在對目標串進行掃描,看看對應的所有位上是否出現,從而判斷是否匹配。分析一下復雜度,大概是O(m+n)。
實現代碼如下:
//強大的和諧系統 int is_contain(char *src, char *des) {//創建一個哈希表,并初始化const int tableSize = 256;int hashTable[tableSize];int len,i;for(i = 0; i < tableSize; i++)hashTable[i] = 0;len = strlen(src);for(i = 0; i < len; i++)hashTable[src[i]] = 1;len = strlen(des);for(i = 0; i < len; i++){if(hashTable[des[i]] == 0)return 0; //匹配失敗}return 1; //匹配成功 }
?
總結
以上是生活随笔為你收集整理的程序员面试100题之十四:强大的和谐的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 位运算的应用和分治法在二进制中的应用
- 下一篇: 面试智力题:天平称球