题解 | #字符串通配符#

字符串通配符

http://www.nowcoder.com/practice/43072d50a6eb44d2a6c816a283b02036

#include <stdio.h>
#include <string.h>
// i,j 匹配 相同 ++ ,? i++,j++  * i++ j+去匹配

int main()
{
  char std[200];
  char str[200];
  int cmp_str(char *std, char *str);
  while (fgets(std, 200, stdin) != NULL)
  {
    fgets(str, 200, stdin);

    for (int k = 0; k < strlen(str); k++)
    {
      if (str[k] >= 'A' && str[k] <= 'Z')
        str[k] = str[k] - 'A' + 'a';
    }
    for (int k = 0; k < strlen(std); k++)
    {
      if (std[k] >= 'A' && std[k] <= 'Z')
        std[k] = std[k] - 'A' + 'a';
    }
    //全部替换成小写

    if (cmp_str(std, str))
    {
      printf("true\n");
    }
    else
      printf("false\n");
  }

  return 0;
}

int cmp_str(char *std, char *str)
{
  int i = 0, j = 0;

  while (i < strlen(std) && j < strlen(str))
  {
    if (std[i] == '?')
    {
      if (str[j] >= 'a' && str[j] <= 'z' || str[j] >= '0' && str[j] <= '9')
        j++, i++;
      else
        return 0;
    }
    else if (std[i] == str[j])
      i++, j++;
    else if (std[i] == '*')
    {
      while (std[i + 1] == '*')
        i++;
      //三种情况 匹配0个字符 匹配下一个字符,匹配多个(std不动,还是*在匹配,str下移)
      return cmp_str(std + i + 1, str + j) || cmp_str(std + i + 1, str + j + 1) || cmp_str(std + i, str + j + 1);
    }
    else
      return 0;
  }


  if (i == strlen(std) && j == strlen(str))
    return 1;
  else
    return 0;
}

全部评论
测试不通过 h*hh hhhhh
点赞 回复 分享
发布于 2022-03-07 16:51

相关推荐

头像 会员标识
昨天 17:08
已编辑
牛客_产品运营部_私域运营
腾讯 普通offer 24k~26k * 15,年包在36w~39w左右。
点赞 评论 收藏
分享
10-11 17:30
湖南大学 C++
我已成为0offer的糕手:羡慕
点赞 评论 收藏
分享
废铁汽车人:秋招真是牛鬼蛇神齐聚一堂
点赞 评论 收藏
分享
5 5 评论
分享
牛客网
牛客企业服务