c++ STL设置自定义比较器

C++ STL set custom comparator

本文关键字:比较器 自定义 设置 STL c++      更新时间:2023-10-16

我有一个问题,排序一组字符串自定义比较器。我会根据字符串长度来排序。

struct CompareLenght
{
    bool operator()(const std::string s1, const std::string s2) const
    {return (s1.size()>s2.size());}        
}
class SearchEngine
{
    private:
    void Associate(const std::vector<std::string> &Files);
    public:   
    SearchEngine(const std::vector<std::string> &Files);  
    void Search(const std::string &frase, std::set<std::string> *S);
};
class FindWord
{
    private:
    std::set<std::string> Parole_Univoche; 
    public:  
    FindWord(const std::string &str);
    inline void Get_Word(std::set<std::string> *Set_Of_Word); 
};
inline void FindWord::Get_Word(std::set<std::string> *Set_Of_Word)
{  
    *Set_Of_Word = Parole_Univoche;
}

当我尝试这样做时问题来了:

void SearchEngine::Search(const std::string &phrase, std::set<std::string> *S)
{
    FindWord F(phrase);                             
    std::set<std::string,CompareLenght> Keyword;             
    F.Get_Word(&Keyword);   
    // some code
}

错误是:

In file included from main.cc:15:0:
SearchEngineNew.cc: In member function ‘void SearchEngine::Search(const string&, std::set<std::basic_string<char> >*)’:
SearchEngineNew.cc:69:33: error: no matching function for call to ‘FindWord::Get_Word(std::set<std::basic_string<char>, cmp>*)’
              F.Get_Word(&Keyword);       
                                 ^
SearchEngineNew.cc:69:33: note: candidate is:
In file included from main.cc:14:0:
FindWord.cc:39:13: note: void FindWord::Get_Word(std::set<std::basic_string<char> >*)
 inline void FindWord::Get_Word(std::set<std::string> *Set_Of_Word)
             ^
FindWord.cc:39:13: note:   no known conversion for argument 1 from ‘std::set<std::basic_string<char>, cmp>*’ to ‘std::set<std::basic_string<char> >*’

如何解决这个问题?非常感谢!

您正在传递&关键字,其类型为:

std::set<std::string,CompareLenght> Keyword;

到参数类型为

的方法
std::set<std::string>*

这些类型的区别在于Get_Word参数类型中缺少comparelength。您可以将此方法作为模板方法来接受任何类型的KeyWord,或者添加重载方法。或者直接将Get_Word更改为:

inline void Get_Word(std::set<std::string,CompareLenght> *Set_Of_Word); 
                                          ^^^^^^^^^^^^^

但是你必须将这个更改传播到你的Parole_Univoche或手动复制Set_Of_Word,就像这样:

typedef std::set<std::string> set_type;
for ( set_type::const_iterator citr = Parole_Univoche.begin(); citr != Parole_Univoche.end(); ++citr ) {
    Set_Of_Word->insert(*citr);
}

您定义的set为

std::set<std::string,CompareLenght> Keyword;

表示关键字的类型是std::set<std::string,CompareLenght>,但是函数Get_Word具有std::set<std::string> *类型的参数

inline void FindWord::Get_Word(std::set<std::string> *Set_Of_Word)
           {  *Set_Of_Word = Parole_Univoche;} 

按如下方式修改

inline void FindWord::Get_Word(std::set<std::string, CompareLenght> *Set_Of_Word)
           {  *Set_Of_Word = Parole_Univoche;} 

似乎函数应该定义为

inline void FindWord::Get_Word(std::set<std::string, CompareLenght> *Set_Of_Word)
           {  Parole_Univoche = *Set_Of_Word; }

因为赋值

没有任何意义
*Set_Of_Word = Parole_Univoche;

也是数据成员

std::set<std::string> Parole_Univoche;

也应该定义为

std::set<std::string, CompareLenght> Parole_Univoche;