C++ Primer 学习中。。。

简单记录下我的学习过程 (代码为主)

//全部容器适用

nth_element(b,n,e)

nth_element(b,n,e,p)

对照:partition()算法



/**------http://blog.csdn.net/u010579068------**/
#include<iostream>
#include<cstdio>
#include<string>
#include<vector>
#include<list>
#include<functional>
#include<deque>
#include<algorithm>
using namespace std; /*****************************************
//全部容器适用
nth_element(b,n,e)
nth_element(b,n,e,p)
对照:partition()算法
*****************************************/
/**---------------------------------------------------------------------------------- ----------------------------------------------------------------------------------**/
/*************************************************************************************
std::nth_element 全部排序容器适用 algorithm
--------------------------------------------------------------------------------------
template <class RandomAccessIterator>
void nth_element ( RandomAccessIterator first, RandomAccessIterator nth,
RandomAccessIterator last ); template <class RandomAccessIterator, class Compare>
void nth_element ( RandomAccessIterator first, RandomAccessIterator nth,
RandomAccessIterator last, Compare comp );
//eg: *************************************************************************************/ bool myfunction (int i,int j)
{
return (i>j);
} int main ()
{
int m[]= {3,4,5,6,7,2,3,4,5,6,1,2,3,4,5};
vector<int> myvector(m,m+15);
vector<int>::iterator it; // set some values:
// for (int i=1; i<10; i++) myvector.push_back(i); // 1 2 3 4 5 6 7 8 9 // random_shuffle (myvector.begin(), myvector.end()); cout << "myvector contains:(原始数据)";
for (it=myvector.begin(); it!=myvector.end(); ++it)
cout << " " << *it; cout << endl;
// using default comparison (operator <):
// cout<<*(myvector.begin()+3)<<endl;
nth_element (myvector.begin(), myvector.begin()+3, myvector.end()); cout << "myvector contains:(从小到大)";
for (it=myvector.begin(); it!=myvector.end(); ++it)
cout << " " << *it; cout << endl; // using function as comp
// cout<<*(myvector.end()-4)<<endl;
// nth_element (myvector.begin(), myvector.begin()+3, myvector.end(),myfunction);
nth_element (myvector.begin(), myvector.end()-4, myvector.end(),greater<int>());
// print out content:
cout << "myvector contains:(从大到小)";
for (it=myvector.begin(); it!=myvector.end(); ++it)
cout << " " << *it; cout << endl; return 0;
}

最新文章

  1. python基础之运算符
  2. 几个容易被忽略的mysql知识
  3. css3爆炸效果更换图片轮播图
  4. 免费的SSL证书,免费为微信小程序搭建https
  5. C++ Unicode SBCS 函数对照表
  6. C++11for循环
  7. centos 安装vnc服务
  8. struts2笔记08-初识ActionSupport
  9. NodeJS的Cluster模块使用
  10. [国嵌笔记][010][TFTP与NFS服务器配置]
  11. [ZJOI2010]基站选址
  12. 小程序第三方框架对比 ( wepy / mpvue / taro )(转)
  13. 学习Markdown
  14. 【PostgreSQL】资料索引(来源:德哥)
  15. WEB学习笔记1-综述
  16. OneZero第二次站立会议(2016.3.22)
  17. redis 学习札记4-sortset
  18. R绘制中国地图,并展示流行病学数据
  19. LTE-Advanced(4G)主要技术学习:CA、CoMp、HetNet
  20. vue表单验证--veevalidate使用教程

热门文章

  1. linux 在线实验
  2. Docker修改hosts方法
  3. 一步步教会你微信小程序的登录鉴权
  4. Meson使用
  5. Hadoop MapReduce编程 API入门系列之二次排序(十六)
  6. Unity3d Time
  7. (转)shiro权限框架详解05-shiro授权
  8. RxSwift の Observable とは何か
  9. 应用二:Vue之ElementUI Form表单校验
  10. Kattis - Game Rank