當前位置:編程學習大全網 - 源碼破解 - C++實現從字符串中查找是否含有另壹段字符串

C++實現從字符串中查找是否含有另壹段字符串

1. 使用庫函數

string.h

strstr函數

函數名: strstr

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

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

說明:返回指向第壹次出現str2位置的指針,如果沒找到則返回NULL。

調用函數,判斷返回值是否等於NULL,決定是否輸出

如;

char *p=".c"; //需要的子串

if(strstr(A,p)) printf("%s",A);

2. 不使用庫函數

第壹行是要查找的字符串

第二行是被查找句子

輸出要查找的字符串在被查找句子的首個位置

#include<stdio.h>

#include<string.h>

void main()

{

int i,j,la,lb,num=0;

char c,a[120],b[4500];

while((c=getchar())!='\n') a[num++]=c;a[num]='\0';

num=0;

while((c=getchar())!='\n') b[num++]=c;b[num]='\0';

la=strlen(a);lb=strlen(b);

for(i=0;(lb-i)>=la;i++)

{if(b[i]==a[0])

{for(j=0;j<la;j++)

if(b[i+j]!=a[j]) break;

if(j==la) {printf("%d\n",i+1);break;}

}

}

}

3. 使用指針

#include "stdio.h"

#include "conio.h"

#include "string.h"

int main()

{

char str[20]="jsdlaadf",substr[10]="sdf";

char *p=str,*q=substr;

int flag=0;

for(;*(p+strlen(substr)-1);p++)

{

for(q=substr;*p==*q&&*q;p++,q++);

if(!*q)

{

flag=1;

break;

}

}

if(flag==1) puts("accord");

else puts("not accord");

system("pause");

}

  • 上一篇:深圳市飛普光電照明科技有限公司怎麽樣?
  • 下一篇:星光大道總冠軍是誰?
  • copyright 2024編程學習大全網