c语言 strstr
时间: 2023-11-14 11:12:05 浏览: 93
C语言中的strstr函数是一个字符串函数,用于在一个字符串中查找另一个字符串的第一次出现。它的原型为char *strstr(const char *str1, const char *str2),其中str1是要查找的字符串,str2是要查找的子字符串。如果找到了子字符串,则返回指向str1中第一次出现的str2的指针;如果str2不是str1的一部分,则返回空指针。在使用strstr函数时,需要包含头文件<string.h>。
相关问题
c语言strstr 实现
C语言中的`strstr`函数用于在一个字符串中查找另一个字符串的出现位置。下面是一个简单的实现:
```c
#include <stdio.h>
#include <string.h>
char* my_strstr(const char* haystack, const char* needle) {
int len_haystack = strlen(haystack);
int len_needle = strlen(needle);
if (len_needle > len_haystack) {
return NULL;
}
for (int i = 0; i <= len_haystack - len_needle; i++) {
int j;
for (j = 0; j < len_needle; j++) {
if (haystack[i+j] != needle[j]) {
break;
}
}
if (j == len_needle) {
return (char*) &haystack[i];
}
}
return NULL;
}
int main() {
char haystack[] = "Hello, world!";
char needle[] = "world";
char* result = my_strstr(haystack, needle);
if (result != NULL) {
printf("'%s' found at position %ld\n", needle, result - haystack);
} else {
printf("'%s' not found\n", needle);
}
return 0;
}
```
这段代码中,`my_strstr`函数接收两个参数,分别是要查找的字符串`haystack`和待查找的字符串`needle`。函数首先计算`haystack`和`needle`的长度,如果`needle`的长度大于`haystack`的长度,则直接返回`NULL`。接着使用两重循环遍历`haystack`,在第一重循环中,遍历的结束条件为`i <= len_haystack - len_needle`,这是因为如果`haystack`的剩余长度小于`needle`的长度,就不用再进行查找了。在第二重循环中,遍历`needle`中的每一个字符,如果有任意一个字符不相等,则退出循环,否则继续比较下一个字符。如果在循环内部没有退出,则说明`needle`完全匹配了`haystack`的一段子串,返回该子串的起始位置即可。如果整个函数执行完毕还没有返回,则说明`needle`在`haystack`中不存在,返回`NULL`。最后在`main`函数中,调用`my_strstr`函数,并根据返回值输出结果。
C语言 strstr函数
C语言中的`strstr()`函数用于在一个字符串中查找另一个字符串的出现位置,其函数声明为`char *strstr(const char *str1, const char *str2)`。其中,`str1`为要查找的字符串,`str2`为要查找的子字符串。如果`str2`是`str1`的一部分,则返回指向`str1`中第一次出现`str2`的指针;否则返回空指针。
以下是一个使用`strstr()`函数的示例代码:
```c
#include <stdio.h>
#include <string.h>
int main() {
char str[] = "This is a simple string";
char* pch;
pch = strstr(str, "simple");
if (pch != NULL) strncpy(pch, "sample", 6);
puts(str);
return 0;
}
```
上述代码中,首先定义了一个字符串`str`,然后使用`strstr()`函数查找字符串中是否包含子字符串`simple`,如果包含,则将其替换为`sample`。最后输出替换后的字符串。
阅读全文