亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

C語(yǔ)言

C語(yǔ)言中strstr()函數(shù)的使用分析

時(shí)間:2024-08-03 09:29:52 C語(yǔ)言 我要投稿
  • 相關(guān)推薦

C語(yǔ)言中strstr()函數(shù)的使用分析

  strstr() 函數(shù)搜索一個(gè)字符串在另一個(gè)字符串中的第一次出現(xiàn),用于判斷字符串str2是否是str1的子串。以下是百分網(wǎng)小編搜索整理的關(guān)于C語(yǔ)言中strstr()函數(shù)的使用分析,供參考借鑒,希望對(duì)大家有所幫助!想了解更多相關(guān)信息請(qǐng)持續(xù)關(guān)注我們應(yīng)屆畢業(yè)生考試網(wǎng)!

  原型:char *strstr(const char *str1, const char *str2);

  #include<string.h>

  找出str2字符串在str1字符串中第一次出現(xiàn)的位置(不包括str2的串結(jié)束符)。返回該位置的指針,如找不到,返回空指針。

  Returns a pointer to the first occurrence of strSearch in str, or NULL if strSearch does not appear in str. IfstrSearch points to a string of zero length, the function returns str.

  代碼如下:

  #include <stdio.h>

  #include <conio.h>

  #include <string.h>

  #include <stdlib.h>

  #pragma warning (disable:4996)

  char *mystrstr(char *s1,char *s2);

  int main(void)

  {

  char *s="Golden Global View";

  char *l="ob";   //char *l=""

  char *p;

  system("cls");

  p=mystrstr(s,l);

  if (p!=NULL)

  {

  printf("%sn",p);

  }

  else

  {

  printf("Not Found!n");

  }

  getch();

  return 0;

  }

  /*FROM 百科*/

  char *mystrstr(char *s1,char *s2)

  {

  int n;

  if (*s2)                      //兩種情況考慮

  {

  while(*s1)

  {

  for (n=0;*(s1+n)==*(s2+n);n++)

  {

  if (!*(s2+n+1))            //查找的下一個(gè)字符是否為''

  {

  return (char*)s1;

  }

  }

  s1++;

  }

  return NULL;

  }

  else

  {

  return (char*)s1;

  }

  }

  另一個(gè)實(shí)現(xiàn):

  代碼如下:

  char *  strstr (buf, sub)

  register char *buf;

  register char *sub;

  {

  register char *bp;

  register char *sp;

  if (!*sub)

  return buf;

  while (*buf)

  {

  bp = buf;

  sp = sub;

  do {

  if (!*sp)

  return buf;

  } while (*bp++ == *sp++);

  buf += 1;

  }

  return 0;

  }

  又一個(gè)實(shí)現(xiàn):

  代碼如下:

  #include <iostream>

  #include <string>

  using namespace std;

  //c語(yǔ)言實(shí)現(xiàn)strstr

  const char* isSub(const char* str, const char *subs){

  //特殊情況

  if(!*subs)

  return str;

  const char* tmp=str;

  while (*tmp!='')

  {

  //用于每次將父串向后移動(dòng)一個(gè)字符

  const char* tmp1=tmp;

  //記錄子串地址

  const char* sub1=subs;

  while (*sub1!=''&&*tmp1!='')

  {

  //若不相等則跳出,將父串后移一個(gè)字符

  if (*sub1!=*tmp1)

  break;

  //若相等且子串下一個(gè)字符是末尾則是這個(gè)父串的子串

  if (*sub1==*tmp1&&*(sub1+1)=='')

  return tmp;

  //若相等則繼續(xù)比較下一個(gè)字符

  if (*sub1==*tmp1)

  {

  sub1++;

  tmp1++;

  }

  }

  tmp++;

  }

  return NULL;

  }

  int main(){

  char* str1="ababcdddb";

  char* str="";

  const char *res=isSub(str1,str);

  if (res!=NULL)

  {

  cout << res << endl;

  }

  else

  cout << "null" << endl;

  //cout << isSub(str1,str) << endl;

  return 0;

  }

【C語(yǔ)言中strstr()函數(shù)的使用分析】相關(guān)文章:

C語(yǔ)言中strpbr()函數(shù)的用法07-25

c語(yǔ)言中time函數(shù)的用法08-27

C 語(yǔ)言中宏的使用08-02

C語(yǔ)言中isalnum()函數(shù)和isalpha()函數(shù)的對(duì)比10-12

C語(yǔ)言中函數(shù)的區(qū)分有哪些10-25

C語(yǔ)言中friend友元函數(shù)詳細(xì)解析06-05

c語(yǔ)言中指針的使用方法10-12

C語(yǔ)言中返回字符串函數(shù)的實(shí)現(xiàn)方法09-19

C語(yǔ)言中volatile關(guān)鍵字分析07-26

c語(yǔ)言中關(guān)于使用BF-KMP算法實(shí)例10-15