模板模式--哈希表排序

c++源码


#include <iostream>

#include <string>
#include <map>
#include <vector>
#include<algorithm>
using namespace std;
typedef pair<string,int>PAIR;
 bool cmp_by_value(const PAIR& p,const PAIR &a)
    {
        return p.second<a.second;
    }
struct cmp
{
    bool operator()(const string& k1, const string& k2) {
    return k1.length() <= k2.length();
  }
};


class Duck
{
    public:
    string name;
    int weight;
    Duck(const string &s,int w):name(s),weight(w){}
    bool operator<(const Duck &d)const
   {
       return weight<d.weight;
   }
};
void display(vector<PAIR>ducks)
{
    for(vector<PAIR>::iterator iter=ducks.begin();iter!=ducks.end();iter++)
    {
        cout<<(*iter).first<<"  "<<(*iter).second<<endl;
    }
}
int main()
{
    map<string,int,cmp>m;//相同时看perate中的比较有没有等号如果有则不会被替代
    m["Daffy"]=8;
    m["Dewey"]=2;
    m["Howard"]=7;
    m["Donald"]=10;
    vector<PAIR>ducks(m.begin(),m.end());
    cout<<"Before sorting"<<endl;
    display(ducks);
    cout<<"Afer sorting"<<endl;
    sort(ducks.begin(),ducks.end(),cmp_by_value);
    display(ducks);


    cout<<"下面是按key排序"<<endl;


    sort(ducks.begin(),ducks.end());
    display(ducks);




    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值