c++ - 如何使 map::find 操作不区分大小写?

标签 c++ string dictionary stl case-insensitive

map::find 方法是否支持不区分大小写的搜索?我有一张 map 如下:

map<string, vector<string> > directory;

并希望以下搜索忽略大小写:

directory.find(search_string);

最佳答案

默认情况下不会。您必须提供一个自定义比较器作为第三个参数。以下代码段将帮助您...

  /************************************************************************/
  /* Comparator for case-insensitive comparison in STL assos. containers  */
  /************************************************************************/
  struct ci_less : std::binary_function<std::string, std::string, bool>
  {
    // case-independent (ci) compare_less binary function
    struct nocase_compare : public std::binary_function<unsigned char,unsigned char,bool> 
    {
      bool operator() (const unsigned char& c1, const unsigned char& c2) const {
          return tolower (c1) < tolower (c2); 
      }
    };
    bool operator() (const std::string & s1, const std::string & s2) const {
      return std::lexicographical_compare 
        (s1.begin (), s1.end (),   // source range
        s2.begin (), s2.end (),   // dest range
        nocase_compare ());  // comparison
    }
  };

std::map< std::string, std::vector<std::string>, ci_less > myMap; 一样使用它

注意:std::lexicographical_compare 有一些细节。如果您考虑语言环境,字符串比较并不总是那么简单。见 this如果有兴趣,请在 c.l.c++ 上讨论。

更新:使用 C++11 std::binary_function已弃用且没有必要,因为类型是自动推断的。

  struct ci_less
  {
    // case-independent (ci) compare_less binary function
    struct nocase_compare
    {
      bool operator() (const unsigned char& c1, const unsigned char& c2) const {
          return tolower (c1) < tolower (c2); 
      }
    };
    bool operator() (const std::string & s1, const std::string & s2) const {
      return std::lexicographical_compare 
        (s1.begin (), s1.end (),   // source range
        s2.begin (), s2.end (),   // dest range
        nocase_compare ());  // comparison
    }
  };

关于c++ - 如何使 map::find 操作不区分大小写?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1801892/

相关文章:

c# - 提高 F# map 插入性能

emacs - 我使用的是 ispell 还是 aspell,本地字典保存在哪里?

c++ - 抛出临时变量而不是局部变量 - 为什么?

c++ - 隐式转换不起作用

java - 关于Java堆空间字符串对象存储的查询

c - 如何部分比较 C 中的两个字符串?

C 语言中关于字符串的困惑

c++ - 模板参数和 std::function 参数的推导

c++ - 如何重载 operator new 和 delete 来跟踪内存?

Python在不使用内置函数的情况下获取字典中最高值的键