在STL地图中排序顺序并设置

时间:2010-07-30 09:24:10

标签: c++ stl

用户定义的对象如何按地图排序并设置? 据我所知,map / set是Sorted Associative Containers:插入的元素是根据它所持有的键进行排序的。

但是map和set内部使用operator >来对元素进行排序。

在SGI网站上,我有以下示例:

struct ltstr
{
    bool operator()(const char* s1, const char* s2) const
    {
        return strcmp(s1, s2) < 0;
    }
};

int main()
{
    map<const char*, int, ltstr> months;

    months["january"] = 31;
    months["february"] = 28;
    months["march"] = 31;
    months["april"] = 30;
    months["may"] = 31;
    months["june"] = 30;
    months["july"] = 31;
    months["august"] = 31;
    months["september"] = 30;
    months["october"] = 31;
    months["november"] = 30;
    months["december"] = 31;

    cout << "june -> " << months["june"] << endl;

    map<const char*, int, ltstr>::iterator cur  = months.find("june");
    map<const char*, int, ltstr>::iterator prev = cur;
    map<const char*, int, ltstr>::iterator next = cur;

    ++next;
    --prev;

    cout << "Previous (in alphabetical order) is " << (*prev).first << endl;
    cout << "Next (in alphabetical order) is " << (*next).first << endl;
}

在上面的例子中,值是如何排序的?

编辑:代码已从评论中移除:

typedef map <string, int> Mint ;

int main() 
{
    string Name ;
    int Marks;
    Mint Grade;
    for (int i = 0; i<4; i++) 
    {
        cin>> Name ; 
        cin >> Marks; 
        Grade [Name] = Marks ; 
    } 
    Mint :: iterator iter; 
    for( iter = Grade.begin(); iter != Grade.end(); iter++)
        cout<< (*iter).first<<“ \t ” <<(*iter).second<<“\n” ; 
    return 0; 

} 

如何对值进行排序?

2 个答案:

答案 0 :(得分:8)

std::map使用仿函数对元素进行排序。默认情况下,std::less<Key>使用operator<。在您的示例中,有一个用户定义的仿函数ltstr,它将帮助按字母顺序按键对元素进行排序。

答案 1 :(得分:3)

默认情况下,首先使用operator<,而不是operator>。在您的情况下,您通过在创建地图对象时传递第三个模板参数来传递自定义比较函数。在将每个元素插入到地图时,该比较仿函数用于确定地图中对象的相对排序,即用于比较键。例如,当您执行months["february"] = 28;时,map会比较“january”和“Feb”的关键字。由于我们正在进行字符串比较,因此该比较返回大于0的值。该值用于确定键“二月”相对于“一月”的位置。