#include<stdio.h>
#include<string.h>
int main()
{ char stra[100],strb[100];
int n,m,i,t,k;
printf("请输入字符串a:");
gets(stra);
printf("请输入字符串b:");
gets(strb);
n=strlen(stra);
m=strlen(strb);
for(i=1;i+m<=n;i++)
{
for(k=0;k<=m;k++)
{
if(stra[i]==strb[0])
{
t=i+1;
}
else if(stra[i]==strb[k])
{
t=i+1;
}
}
}
printf("第一次出现是位置为%d",t);
}
你这个逻辑有点乱,可以参考这个,有帮助望采纳!
#include <stdio.h>
#include <string.h>
int main()
{
char a[255] = "";
char b[255] = "";
printf("请输入字符串a:");
scanf("%s", a);
printf("请输入字符串b:");
scanf("%s", b);
char* p = strstr(a, b);
if (p != NULL)
printf("%s第一次出现在%s的位置为:%ld", b, a, p - a);
else
printf("%s不包含%s的子串", a, b);
return 0;
}
改成这样
#include<stdio.h>
#include<string.h>
int main()
{ char stra[100],strb[100];
int n,m,i,k;
printf("请输入字符串a:");
gets(stra);
printf("请输入字符串b:");
gets(strb);
n=strlen(stra);
m=strlen(strb);
bool boo;
for(i=0;i+m<=n;i++)
{
boo=true;
for(k=0;k<m;k++)
{
if(stra[i+k]!=strb[k])
{
boo=false;
break;
}
}
if(boo)
printf("第一次出现是位置为%d",i);
}
}
需要注解再跟我说