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");
}