模拟实现strchr

实现strchr(s,c):查找字符串s中首次出现字符c的位置
程序:

char* Strchr(const char* str1, int  c)
{
 if (str1 != NULL || c != 0)//合法性校验
 {
  return NULL;
 }
  const char* p = str1;
 while (*p != '\0')
 {
  if (*p == c)
  {
   return (char *)p;
  }
  ++p;
 }
 return NULL;
}
int main()
{
 char str1[] = "abcdecde";
 int  c = 'c';
 char* ret=strchr(str1, c);
 if (ret == NULL)
 {
  printf("没找到\n");
 }
 else
 {
  printf("%d\n", *ret);//-&str1+1);
 }
 return 0;
}
strtok函数是C语言中的一个字符串分割函数,它可以将一个字符串按照指定的分隔符进行分割,并返回分割后的子字符串。下面是一个简单的strtok模拟实现: ```c #include <stdio.h> #include <string.h> char* my_strtok(char* str, const char* delim) { static char* p = NULL; if (str != NULL) { p = str; } else { if (p == NULL) { return NULL; } str = p; } char* start = str; while (*p) { if (strchr(delim, *p)) { *p++ = '\0'; return start; } p++; } if (*start == '\0') { return NULL; } else { return start; } } int main() { char str[] = "Hello World! This is a test."; const char delim[] = " "; char* token = my_strtok(str, delim); while (token != NULL) { printf("%s\n", token); token = my_strtok(NULL, delim); } return 0; } ``` 这段代码中的`my_strtok`函数模拟了`strtok`函数的功能。它通过静态变量`p`来保存当前位置,第一次调用时传入字符串指针并保存在`p`中,后续调用传入`NULL`则继续从上次结束的位置开始分割。在每次循环中,它会判断当前字符是否为分隔符,如果是则将其替换为`\0`,并返回上一个分割的子字符串的起始位置。当遇到字符串末尾时,如果上一个分割的子字符串非空,则返回该子字符串,否则返回`NULL`表示已经分割完毕。 这段代码的输出结果为: ``` Hello World! This is a test. ``` 这样就实现了一个简单的strtok模拟函数。注意,这只是一个简单的示例,实际使用时需要考虑更多的边界情况和错误处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值