VC中sort()排序函数的使用

VC的include目录下的algorithm.h文件中有很多数学算法的函数,最近使用了其中的sort()函数,发现在对字符数组排序时存在问题。

该函数原型为sort(_RI _F, _RI _L, [_Pr _P]),其三个参数依次为排序队列第一个元素、最后一个元素和排序算法(默认为升序)。以vector结构为例:

vector<int> v;
sort(v.begin(), v.end);

对于vector元素为整形数据时,排序完全没问题。但如果为char *时,会发现排序后顺序没有变化,没有达到排序的效果。

对于这种情况,我们需要手动编写排序算法函数,参考代码如下:

// 排序算法, a<b返回true
bool pstrcmp(const char *a, const char *b)
{
return strcmp(a, b) < 0;
}

...
vector<char *> v;
sort(v.begin(), v.end(), pstrcmp);
...

相应的,对于int等类型,我们也可以参考这种方式自定义排序算法。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值