求助 : vector排序

Wang471981125 2011-02-19 09:59:08
整形vector的数据为(5,6,3,28,9,。。。)

有一整数 5

经过排序

得到
(5,6,9,28,3,。。。)

请问该如何排序呢

谢谢~~
...全文
245 18 打赏 收藏 转发到动态 举报
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
stock999 2011-02-21
  • 打赏
  • 举报
回复
直接调用STL的std::sort()函数

std::sort( iVect.begin(), iVect.end() ); // 默认升序。

如果要降序的话,你要写1个谓词函数即可。
franzhong 2011-02-21
  • 打赏
  • 举报
回复
顺序排列用冒泡或是递归
Wang471981125 2011-02-21
  • 打赏
  • 举报
回复
[Quote=引用 15 楼 year2002 的回复:]

引用 13 楼 wang471981125 的回复:

引用 9 楼 year2002 的回复:
sort(vec.begin(), vec.end());
vector<int>::iterator iter = std::find(vec.begin(), vec.end(), 5);
if (iter != vec.end())
rotate(vec.begin(), iter……
[/Quote]
JaneThink 2011-02-20
  • 打赏
  • 举报
回复
题目都没考明白,这个排序是怎么排的?
Wang471981125 2011-02-20
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 year2002 的回复:]
sort(vec.begin(), vec.end());
vector<int>::iterator iter = std::find(vec.begin(), vec.end(), 5);
if (iter != vec.end())
rotate(vec.begin(), iter, vec.end());
[/Quote]
find返回为不存在呢

可以有其他办法吗
Wang471981125 2011-02-20
  • 打赏
  • 举报
回复
没办法 。。。。。。。。。。
  • 打赏
  • 举报
回复
[Quote=引用 13 楼 wang471981125 的回复:]

引用 9 楼 year2002 的回复:
sort(vec.begin(), vec.end());
vector<int>::iterator iter = std::find(vec.begin(), vec.end(), 5);
if (iter != vec.end())
rotate(vec.begin(), iter, vec.end());

find返回为不存在呢
……
[/Quote]

那用lower_bound代替find返回第一个大于等于5的值
做鸡真好吃 2011-02-19
  • 打赏
  • 举报
回复
排序规则没看明白,能说明吗?
icefairy 2011-02-19
  • 打赏
  • 举报
回复
完全没规律的排序 。。。
zzz_zou 2011-02-19
  • 打赏
  • 举报
回复
排序 ?、

是智力问题吧? 排列?
奋斗吧 2011-02-19
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 year2002 的回复:]
sort(vec.begin(), vec.end());
vector<int>::iterator iter = std::find(vec.begin(), vec.end(), 5);
if (iter != vec.end())
rotate(vec.begin(), iter, vec.end());
[/Quote]
C++基础很扎实的牛人
欣客 2011-02-19
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 year2002 的回复:]
sort(vec.begin(), vec.end());
vector<int>::iterator iter = std::find(vec.begin(), vec.end(), 5);
if (iter != vec.end())
rotate(vec.begin(), iter, vec.end());
[/Quote]

+1
  • 打赏
  • 举报
回复

sort(vec.begin(), vec.end());
vector<int>::iterator iter = std::find(vec.begin(), vec.end(), 5);
if (iter != vec.end())
rotate(vec.begin(), iter, vec.end());
fishion 2011-02-19
  • 打赏
  • 举报
回复
先一遍循环,把小于5的数据都删除插到最后,最后就记录没有删除操作的数据有多少,再用algorithm中的sort来进行排序
Wang471981125 2011-02-19
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 tandyt 的回复:]

这个要找到规律才能排序,比如是按照某个公式或者某个表来排的,否则,咋一看,这根本就是乱序,怎么排?
[/Quote]
没说清楚

顺序增大 然后从中间交换位置
TandyT 2011-02-19
  • 打赏
  • 举报
回复
这个要找到规律才能排序,比如是按照某个公式或者某个表来排的,否则,咋一看,这根本就是乱序,怎么排?
  • 打赏
  • 举报
回复
你的意思是比5小的排到最后?
先调sort,再find到5,再根据找到的迭代器rotate

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧