只做嵌入式 2021-11-11 20:43 采纳率: 42.9%
浏览 6
已结题

要求各位实现字符串通配符的算法

问题描述:在计算机中,通配符一种特殊语法,广泛应用于文件搜索、数据库、正则表达式等领域。现要求各位实现字符串通配符的算法。
要求:
实现如下2个通配符:
:匹配0个或以上的字符(注:能被和?匹配的字符仅由英文字母和数字0到9组成,下同)
?:匹配1个字符

注意:匹配时不区分大小写。

img

  • 写回答

1条回答 默认 最新

  • 从善若水 5G/6G通信领域优质创作者 2021-11-11 20:50
    关注
    
    // 用递归就可以了
    #include <iostream>
    #include <string>
    using namespace std;
    
    bool match(const char* pattern, const char *str)
    {
        if (*pattern == '\0' && *str == '\0')
            return true;
        if (*pattern == '\0' || *str == '\0')
            return false;
    
        if (*pattern == '?')
        {
            return match(pattern + 1, str + 1);
        }
        else if (*pattern == '*')
        {
            // 匹配0个1个或多个
            return match(pattern + 1, str) || match(pattern + 1, str + 1) || match(pattern, str + 1); 
        }
        else if (*pattern == *str)
        {
            return match(pattern + 1, str + 1);
        }
    
        return false;
    }
    int main(void)
    {
        string pattern, str;
        while (cin >> pattern >> str)
        {
            bool ret = match(pattern.c_str(), str.c_str());
            if (ret)
                cout << "true" << endl;
            else
                cout << "false" << endl;
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月20日
  • 已采纳回答 11月12日
  • 创建了问题 11月11日

悬赏问题

  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥15 this signal is connected to multiple drivers怎么解决
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥66 如何制作支付宝扫码跳转到发红包界面
  • ¥15 pnpm 下载element-plus