Chinaunix首页 | 论坛 | 博客
  • 博客访问: 68194
  • 博文数量: 24
  • 博客积分: 410
  • 博客等级: 一等列兵
  • 技术积分: 240
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-16 19:10
文章分类
文章存档

2011年(24)

分类: C/C++

2011-04-04 00:14:49

函数名: strstr

  功 能: 在字符串中查找指定字符串的第一次出现

  用 法: char *strstr(char *str1, char *str2);

  strstr原型:extern char *strstr(char *haystack, char *needle);

  用法:#include

  功能:从字符串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 NULL;

  }

  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

  #include

  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;

  }

阅读(1062) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~