C中的std :: string是否有内置函数,当字符串可以是大写或小写时,按字母顺序比较两个字符串?

我知道对于C来说,如果两个词都是完全较低或完全是大写的话,那么基本的比较运算符就可以完成任务.我有一个字符串数组,字母可以从低到高不等.这是我可以使用的字符串的一个小问题:

“丰富的生活CH”

“新生活WMN MNSTRY”

“新生活大会”

我知道Java中存在函数String.compareToIgnoreCase().这个函数有C等价吗?

解决方法

我不知道标准库中的任何不区分大小写的函数,但您可以为std :: equal指定自定义谓词:
std::string a("hello");
std::string b("HELLO");
std::cout << std::equal(a.begin(),a.end(),b.begin(),[] (const char& a,const char& b)
    {
        return (std::tolower(a) == std::tolower(b));
    });

有关考虑区域设置的解决方案,请参阅Case insensitive std::string.find().

#include <locale>

template<typename charT = std::string::value_type>
struct my_equal {
    my_equal( const std::locale& loc ) : loc_(loc) {}
    bool operator()(charT ch1,charT ch2) {
        return std::toupper(ch1,loc_) == std::toupper(ch2,loc_);
    }
private:
    const std::locale& loc_;
};

int main()
{
    std::string a("hello");
    std::string b("HELLO");
    std::cout << std::equal(a.begin(),my_equal<>(std::locale()));
}

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...