1. 程式人生 > >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");
}