题目
由键盘输入两个字符串(假设第一个字符串必包含第二个字符串,如第一个字符串为ABCDEF,第二个为CDE, 则CDE包含在ABCDEF中),现要求编程输出第二字符串在第一行字符串中出现的位置。 (如果第二个字符串在第一个字符串中出现多次,则以最前出现的为准)
解题思路
喵第一反应就是for循环的嵌套……首先判断第一个字符串中的字符是否有与第二个字符串首个字符相同的,如果有继续判断下面的字符相不相同,不相同break内循环然后进行下一个外循环……输出的话就是字符串中的i+1.
这个题目顺便让我复习了一下break,continue和return的用法。差点卡在那里出不去。喵。
QAQ然后看了一下标程发现果然还是有更简洁的喵……
#include "stdio.h"
#include "string.h"
main()
{
char b[30];
char a[30];
int i,j,z,k,n,m=0;
gets(a);
gets(b);
z=strlen(a);
k=strlen(b);
for(i=0;i<z;i++)
{
if(a[i]==b[0])
{
m=0;
for(n=i,j=0;j<k;n++,j++)
{
if(a[n]!=b[j])
{
m=1;break;
}
}
if(m==0) break;
}
}
if(m==0) printf("%d",i+1);
else printf("NO FOUND");
}