#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);
}
输入字符串a和b,在字符串a中找出字符串b第一次出现的位置。请问我这个该怎么改?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
关注你这个逻辑有点乱,可以参考这个,有帮助望采纳!
#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; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?评论 打赏 举报解决 1无用