m0_69966381 2022-04-21 18:10 采纳率: 80%
浏览 361
已结题

输入字符串a和b,在字符串a中找出字符串b第一次出现的位置。请问我这个该怎么改?

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

  • 写回答

2条回答 默认 最新

  • 不会长胖的斜杠 新星创作者: 后端开发技术领域 2022-04-21 18:18
    关注

    你这个逻辑有点乱,可以参考这个,有帮助望采纳!

    #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;
    }
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月29日
  • 已采纳回答 4月21日
  • 创建了问题 4月21日