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