c++中vector排序的问题

如果是一个vector<int>,怎么按照vector元素出现的次数来排序,然后取出出现次数最多的几个元素呢?(注意是按次数排序不是按值的大小啊)... 如果是一个vector<int>,怎么按照vector元素出现的次数来排序,然后取出出现次数最多的几个元素呢? (注意是按次数排序不是按值的大小啊) 展开
 我来答
司琅0Iid5b
推荐于2016-09-24 · TA获得超过802个赞
知道小有建树答主
回答量:319
采纳率:0%
帮助的人:617万
展开全部
你好,可以利用map实现。

以下是代码,请参考:

// copyright @ quark
// date: 2010-10-19

#include <vector>
#include <iostream>
#include <map>
#include <algorithm>
using namespace std;

void paixu(vector<int>&ivec,int topnum)//选出出现次数最多的topnum个,其余删除
{
vector<int>::iterator iter=ivec.begin();
map<int ,int >m;
for (iter;iter!=ivec.end();++iter)
{
m[*iter]++;
}

if (topnum>m.count())
{
return;
}

// 循环遍历map对象,输出最多出现的元素
for (int i=0;i<topnum;i++)
{

pair<int,int> maxPair;
map<int,int>::const_iterator iter = m.begin();
while (iter!=m.end())
{
if ((*iter).second > maxPair.second)
{
maxPair = *iter;
}
iter++;
}
if (maxPair.second > 0)
{
cout<<i<<"\tvalue:"<<maxPair.first<<"\t\tcount:"<<maxPair.second<<endl;
m.erase(maxPair.first);
}
}

//cout<<m1<<" "<<m2<<" "<<m3<<endl;
}
//bool isgreat()
void main()
{
vector<int> ivec;
ivec.push_back(3);
ivec.push_back(2);
ivec.push_back(1);
ivec.push_back(2);
ivec.push_back(1);
ivec.push_back(1);
ivec.push_back(1);
paixu(ivec,2);

getchar();
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式