C语言不太会,求指点!

2025-01-24 14:03:04
推荐回答(3个)
回答1:

我为你增加了一个函数 mystr,与你想要的意思基本相符。

下面这个是测试图,比如输入 hello, 如果查找 l开头的,则会找到 llo (符合你的要求)


#include

#include

#include 

char *locatesubstr(char *str1,char*str2);

char *mystr(const char *s1, const char *s2);

main()

{

      char str1[500],str2[500];

      char *p;

      printf("Please input one string:");

      gets(str1);

      printf("Please input another string:");

      gets(str2);

      printf("The result is:\n");

      p=mystr(str1,str2);

      puts(p);

      system("pause");

}

 

char *mystr(const char *s1, const char *s2)

{

    int n;

    if (*s2) {

        while (*s1) {

            for(n = 0; *(s1 + n) == *(s2 + n); n ++) {

                if(!*(s2 + n + 1)) 

                    return (char *)s1;

            }

            s1 ++;

        }

        return NULL;

    } else {

        return (char *)s1;

    }

}


char *locatesubstr(char *str1,char*str2)

{

     int k=0;

     while(*str1!='\0')

     {

                      if(*str1==*str2)

                      {

                                     k=1;

                                     return(str1);

                      }

                      str1++;

     }

     if(k==0)

     return(NULL);

}


回答2:

你的程序里有几个问题:
① *p=*locatesubstr(str1,str2); 这个导致你无法正常编译。 应该改为:
p=locatesubstr(str1,str2);
p是指针,定义的时候*p,但用的时候,如果按指针用,就是p,而*p,这取的是p所指的内容;locatesubstr是函数,定义的时候,前面有返回类型char *, 但调用的时候,前面不加*. --这是你基本概念方面的误解;
② 修正了①的错误, 可以编译,可以运行了,但停不下来,很快就出错(溢出了)。原因: while(*str1!='\0')这句,永远满足条件,所以不会结束。 *str1就是str1[0],也即是你输入的第1个字符串的首字符, 比如输入:abc123,那么*str1 == 'a'; 所以你的条件永远满足,p++就越界了。
③ 修正②,其实应该查看的是str2,而且应该引入新变量i,
int i = 0;
...
if(p!=NULL)
{
while(str2[i]!='\0')
{
printf("%c",*p++);
i++;
}
}
else
{
printf("NULL");
}
...
这样结果就正确了。
④ 更好的方法, C的标准库里面有strstr,就是作这个的,如果自己要实现,那么:
int my_strstr(const char *s1, const char *s2)
{
int retcode = -1;
int pos = 0;
size_t n;

if (s1 == NULL)
return -2;

if (s2 == NULL)
return -3;

n = strlen(s2);
printf("n=%d\n", n);
while(*s1)
if(!memcmp(s1++,s2,n))
{
retcode = pos;
break;
}
else
pos++;

return retcode;
}
返回的是pos的int值, 如果要返回指针,也可以,你看明白了,可以自己修改一下。

回答3:

你的程序,离题目要求有点远啊,这个属于经典的字符串匹配问题,已经有很多成型的算法了,看一下这个吧。
http://blog.csdn.net/WINCOL/article/details/4795369