数据结构和算法
- 查找算法
-
字符串查找(单列)
-
- 七大查找算法
- 排序算法:
字符串查找
1. 子字符串查找
从目标串pStr中查找pFindStr,如果有,返回位置下标
eg:
pStr:adcdbcae
pFindStr:dbca- 第一种实现方法
string::size_type string::find(string &);
功能为在string对象中,查找参数string类型的字符串是否存在,如果存在,返回起始位置。不存在则返回 string::npos。
#include <string> int FindStr(string a, string b) { string::size_type idx; idx=a.find(b);//在a中查找b. if(idx == string::npos )//不存在。 { return (int)idx; } return -1; }
- 第二种实现方法
在C语言中,字符串存储为字符数组,以’\0’结束。 在C的接口中,有strstr函数,可以在字符串中查找另一个字符串。
char * strstr(const char *str1, const char *str2);
功能为在str1中查找str2,如果存在,那么返回查找到的起始指针,否则返回NULL。
int FindStr(char* pStr, char* pFindStr) { char* pPos = strstr(pStr, pFindStr); if (!pPos) { return -1; } char* ptr = pstr; int pos = 0; while(ptr) { if(pPos == ptr) return pos; ptr++; pos++ } }
- 第三种实现方法
int FindStr(char* pStr, char* pFindStr) { // 异常情况判断 if(!pStr || !pFindStr) return -1; char* p1 = pStr; char* p2 = pFindStr; char* p3 = NULL; int pos = 0; while(p1) { // 第一个字符相同,比较剩余字符 if(*p1 == *p2) { p3 = p1; while(!p3 && !p2) { if(*p3 != *p2) break; p3++; p2++; } // 查看遍历是否完成 if(!p2) { return pos; } else { // 重置指针 p2 = pFindStr; } } p1++; pos++; } }
2. 相同字符串查找
从两个字符串中找到相同的最大长度的子串,并返回。
eg:
str1:hello word amazing!!!
str2:nihao=hello amazing
思路:
输入两个字符串,由短字符串的长度决定比较次数。
每次比较一个字符,从短字符串的第一个依次与长字符串的每一个字符比较,若出现相同的字符,则两个字符串各自取下一位进行比较,直到出现不相同字符的为止。(同时要注意比较是不能超出短字符串的长度,不然会出现未知后果)string FindMAxSubString( string a ,string b) { string res = ""; string shorter = a.length()>b.length()? b:a; string longer = a.length()>b.length()? a:b; int maxlen =0; int maxpos =-1; for(int i =0; i<shorter.length();i++){ for(int j =0;j<longer.length();j++) { if(shorter[i]==longer[j]) { int k =1; for(;(shorter[i+k]==longer[j+k])&& i+k<shorter.length();k++); if(k>maxlen){ maxpos =i; maxlen =k; } } } } if(maxpos==-1) return res; else { res=shorter.substr(maxpos,maxlen); return res; } }
- 第一种实现方法