zoukankan      html  css  js  c++  java
  • Strstr()函数

    概述实现
      函数名: strstr
      功 能: 在字符串中查找指定字符串的第一次出现
      用 法: char *strstr(char *str1, char *str2);
      strstr原型:extern char *strstr(char *haystack, char *needle);
      用法:#include <string.h>
      功能:从字符串haystack中寻找needle第一次出现的位置(不比较结束符NULL)。
      说明:返回指向第一次出现needle位置的指针,如果没找到则返回NULL。
    函数原型
      1.Copyright 1990 Software Development Systems, Inc.
      char *strstr( const char *s1, const char *s2 )
      {
      int len2;
      if ( !(len2 = strlen(s2)) )
      return (char *)s1;
      for ( ; *s1; ++s1 )
      {
      if ( *s1 == *s2 && strncmp( s1, s2, len2 )==0 )
      return (char *)s1;
      }
      return 0;
      }
      2.Copyright 1986 - 1999 IAR Systems. All rights reserved
      char *strstr(const char *s1, const char *s2)
      {
      int n;
      if (*s2)
      {
      while (*s1)
      {
      for (n=0; *(s1 + n) == *(s2 + n); n++)
      {
      if (!*(s2 + n + 1))
      return (char *)s1;
      }
      s1++;
      }
      return NULL;
      }
      else
      return (char *)s1;
      }
    举例
      // strstr.c  
      #include <syslib.h>
      #include <string.h>
      main()
      {
      char *s="Golden Global View";
      char *l="lob";
      char *p;
      clrscr();
      p=strstr(s,l);
      if(p)
      printf("%s",p);
      else
      printf("Not Found!");
      getchar();
      return 0;
      }
      语法:* strstr(str1,str2)
      str1: 被查找目标 string expression to search.
      str2:要查找对象 The string expression to find.
      该函数返回str2第一次在str1中的位置,如果没有找到,返回NULL
      The strstr() function returns the ordinal position within str1 of the first occurrence of str2. If str2 is not found in str1, strstr() returns 0.
      例子:
      功能:从字串” string1 onexxx string2 oneyyy”中寻找”yyy”
      (假设xxx和yyy都是一个未知的字串)
      char *s=” string1 onexxx string2 oneyyy”;
      char *p;
      p=strstr(s,”string2”);
      if(!p) printf(“Not Found!”);
      p=strstr(p,”one”);
      if(!p) printf(“Not Found!”);
      p+=strlen(“one”)
      printf(“%s”,p);
      说明:如果直接写语句p=strstr(s,”one”),则找到的是onexxx string2 oneyyy,不符合要求
      所以需采用二次查找法找到目标
    实现
      char *mystrstr(char *s1 , char *s2)
      {
      if(*s1==0)
      {
      if(*s2) return(char*)NULL;
      return (char*)s1;
      }
      while(*s1)
      {
      int i=0;
      while(1)
      {
      if(s2[i]==0) return s1;
      if(s2[i]!=s1[i]) break;
      i++;
      }
      s1++;
      }
      return (char*)NULL;
      }
  • 相关阅读:
    抓老鼠啊,亏了还是赚了
    币值转换
    2019春第七周作业
    2019春第六周作业
    2019春第五周作业
    2019年春季学期第四周作业
    2019年春季学期第三周作业
    2019年春季学期第二周作业
    在人生路上对我影响最大的三位老师
    第七周作业
  • 原文地址:https://www.cnblogs.com/eagleking0318/p/6521289.html
Copyright © 2011-2022 走看看