不区分大小写的字符穿搜索函数,自己写的,效率比StrStrI要高

来源:互联网 发布:淘宝店铺钻石 编辑:程序博客网 时间:2024/05/01 11:54

inline char low(char c)
 {
  if( c >='A' && c <= 'Z' )
  {
   return (c + 'a' -'A');
  }
  else
  {
   return c;
  }
 }
//返回首地址,outlen 为字符串的


char* stringcase(const char* src,int srclen,const char* strcharset,int charsetlen)
{
 char *c = new char[charsetlen];
 int i = 0;
 while( (c[i++] = low(*strcharset++)) != '/0' && i < charsetlen); 
 char ctmp;; 
 int j = 0;
 int k = 0;
 
 char* sart = NULL;
 char *info = (char*)src; 
 
 while ( *info != '/0' && k < srclen && j < charsetlen)
 {
  ctmp = low(*info++);
  if(ctmp == c[j]) 
   j++;  
  else
  {
   k +=j;
   k++;
   j=0;
  }

  if(j == charsetlen)
  {
   sart = (char*)src + k;
   break;
  }  
 }
 return sart;
}

原创粉丝点击