加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – strstr有反向功能吗?

发布时间:2020-12-16 05:41:32 所属栏目:百科 来源:网络整理
导读:我正在尝试找到一个类似的strstr函数来搜索从结尾到字符串开头的子字符串. 解决方法 我不知道一个.关于C的好处之一是,如果你编写自己的功能,它就像图书馆一样快速有效. (其他语言完全不是这样). 您可以反转字符串和子字符串,然后搜索. 最后,当字符串库不够好
我正在尝试找到一个类似的strstr函数来搜索从结尾到字符串开头的子字符串.

解决方法

我不知道一个.关于C的好处之一是,如果你编写自己的功能,它就像图书馆一样快速有效. (其他语言完全不是这样).

您可以反转字符串和子字符串,然后搜索.

最后,当字符串库不够好时,人们常常做的另一件事就是移动到正则表达式.

好的,我写了reverse()和rstrstr(),这可能会运行,如果我们是幸运的.摆脱__restrict为C.您也可能需要使参数const,但是您将需要转换返回值.要回答您的评论问题,您可以从子字符串的地址中获取索引,方法是从原始字符串指针中减去它.好:

#include <stdlib.h>
#include <string.h>

char *reverse(const char * __restrict const s)
{
  if (s == NULL)
    return NULL;
  size_t i,len = strlen(s);
  char *r = malloc(len + 1);

  for(i = 0; i < len; ++i)
    r[i] = s[len - i - 1];
  r[len] = 0;
  return r;
}

char *rstrstr(char *__restrict s1,char *__restrict s2)
{
  size_t  s1len = strlen(s1);
  size_t  s2len = strlen(s2);
  char *s;

  if (s2len > s1len)
    return NULL;
  for (s = s1 + s1len - s2len; s >= s1; --s)
    if (strncmp(s,s2,s2len) == 0)
      return s;
  return NULL;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读