strstr函数 实现
/*
strstr 用滚动比较的方法来实现
*/
#include <stdio.h>
int main()
{
char* mystrstr(const char* str1, const char* str2);
char a[101], b[101];
scanf("%s%s", &a, &b);
printf("%s", mystrstr(a, b));
}
char* mystrstr(const char* str1, const char* str2) {
char* p1 = str1;
char* p2 = str2;
int i = 0;
while (*p1)//(*检测到回车'\n'的时候跳出循环)
{
char* flag = p1;//设置标志位,方便回滚。
while (*p1 == *p2 && *p1 != '\0') {
//结束循环的条件有两种:1 ,字符不相等,不是子串 ; 2 ,p2到底了都是相等的, 子串
p1++;
p2++;
}
if (p2=='\0') //第二个字符串走到\n了吗????
{
return flag;
i++;//返回找到子串的起始位置。
}
if (!*p1)
{
//走到这里,p1到达\0 而p2没有到达\0,没有找到
return NULL;
}
//走到这里,没有匹配成功,继续从下一位开始匹配整个子串
p1++;
}
return NULL;
}
接字符串
#include <stdio.h>
void mystrcpy(char str[], char str2[]);
int main()
{
char str1[100], str2[200];
gets(str1);
gets(str2);
f(str1, str2); //传数组名即可不用str[100]!!!
printf("%s", str1);//打印str的地址的内容就可以,不用返回!!!
}
void mystrcpy(char str[], char str2[])
{
int i = 0,a=0;
while (str[i] != '\0')
{
i++;
a = i;
}
for (i = 0; str2[i] != 0; i++)
{
str[a++] = str2[i];
}
str[a] = '\0';//记得给他补回回车
}
strcpy
原型:char *strcpy(char *dst ,char const *src) ;
注意: 因为dst参数将被修改,所以它必须是一个字符数组或者指向动态分配内存的数组的指针 ,不能是字符串常量 。
程序员必须保证目标字符数组的空间足以容纳需要复制的字符串 , 如果字符串比数组要大,依然可以被复制 , 那么数组后面的内存空间就会被覆盖。 (这样对程序来说不是件好事。) ---------------来源于《c与指针》
返回值: 返回第一个参数的一份拷贝,就是一个指向目标字符数组的指针。(大多情况下返回值都被忽略了)
strcat (char *dst ,char const *src) ;
连接字符串,将一个字符串连接到另一个字符串的后面 ;
strcmp
原型:int strcmp (char const *s1 ,char const *s2);
比较两个字符串: s1>s2 返回一个整数
s2>s1 返回一个负数
s2=s1 返回0
strstr 函数: 返回一个s2 第一次出现的位置