当前位置:   article > 正文

STL之算法——排序算法_stl排序

stl排序

一:介绍

常用的STL排序算法包括sort,reverse,merge,random_shuffle。

二:sort:对容器内元素进行排序

1.函数原型

sort(iterator begin, iterator end) 默认以升序方式对元素进行排序

sort(iterator begin, iterator end, _Pred) 自定义方式对元素排序

2.操作

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>
  4. using namespace std;
  5. bool Less(int m, int n)
  6. {
  7. return m < n;
  8. }
  9. bool Greater(int m, int n)
  10. {
  11. return m > n;
  12. }
  13. int main()
  14. {
  15. vector<int> v{ 1,5,3,7,9 };
  16. sort(v.begin(), v.end());//1,3,5,7,9
  17. sort(v.begin(), v.end(), Greater);//9,7,5,3,1
  18. }

三:  reverse:翻转指定范围元素

1.函数原型

reverse(iertator begin, iterator end)

2.操作

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>
  4. using namespace std;
  5. int main()
  6. {
  7. vector<int> v{ 1,5,3,7,9 };
  8. reverse(v.begin(), v.end());//9,7,3,5,1
  9. }

四:merge:容器元素合并,并储存到另一个容器中

1.函数原型

//begin1和begin2必须是有序的,dest_begin遵循输入的排序规则

merge(iterator begin1, iterator end1, iterator begin2, iterator end2, iterator dest_begin)

//begin1和begin2以及dest_begin都必须遵循_Pred的规则

merge(iterator begin1, iterator end1, iterator begin2, iterator end2, iterator dest_begin, _Pred)

2.操作

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>
  4. using namespace std;
  5. bool Less(int m, int n)
  6. {
  7. return m < n;
  8. }
  9. bool Greater(int m, int n)
  10. {
  11. return m > n;
  12. }
  13. int main()
  14. {
  15. vector<int> v{ 1,5,3,7,9 };
  16. vector<int> v1{ 11,15,13,17,19 };
  17. vector<int> v2;
  18. v2.resize(v.size() + v1.size());
  19. sort(v.begin(), v.end());
  20. sort(v1.begin(), v1.end());
  21. //输入两个容器元素必须是有序的,否则会报错
  22. //merge(v.begin(), v.end(), v1.begin(), v1.end(), v2.begin());//
  23. //排序规则必须遵循输入容器的排序规则
  24. merge(v.begin(), v.end(), v1.begin(), v1.end(), v2.begin(), Less);
  25. }

五:random_shuffle:指定范围内的元素随机调整次序

1.函数原型

random_shuffle(iterator begin, iterator end)

//以随机种子rand_func调整次序

random_shuffle(iterator begin, iterator end, rand_func) 

2.操作

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>
  4. #include <random>
  5. using namespace std;
  6. int randFunc(int n)
  7. {
  8. return rand() % n;
  9. }
  10. int main()
  11. {
  12. vector<int> v{ 1,5,3,7,9 };
  13. //random_shuffle(v.begin(), v.end());
  14. srand(unsigned(std::time(0)));//srand函数是随机数发生器的初始化函数。
  15. random_shuffle(v.begin(), v.end(), randFunc);
  16. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/爱喝兽奶帝天荒/article/detail/919432?site
推荐阅读
相关标签
  

闽ICP备14008679号