【C++学习笔记】--4.STL学习

1.nth_element  求第n大的元素,并把把它放在第n位置上。下标从0开始,不返回值。

nth_element(first,nth,last)

first,last 第一个和最后一个迭代器,也可以直接用数组的位置。 
nth,要定位的第n 个元素,能对它进行随机访问.将第n_thn_th 元素放到它该放的位置上,左边元素都小于它,右边元素都大于它.

nth_element(intVect.begin(),intVect.begin()+3,intVect.end());

cout << intVect[3]<< endl;//输出排序时,第四个元素的值

输出中位数:

nth_element(intVect.begin(), intVect.begin() + intVect.size()/2, intVect.end());

cout << "The median is " << intVect[intVect.size()/2] << endl;

nth_element(intVect.begin(), intVect.begin() + 1, intVect.end(), greater<int>());

cout << "The second largest is " << intVect[1] << endl;

The median is 5

The second largest is 7

9 7 6 5 3 1 0

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值