1 // g++ selection_sort.cc -Wall -O3 -std=c++11 && ./a.exe
2
3
4 #include <iostream>
5 #include <vector>
6
7
8 static void swap(int &a, int &b) {
9 int temp = a;
10 a = b;
11 b = temp;
12 }
13
14 static size_t GetIndexOfMin(std::vector<int> &arr, size_t begin) {
15 size_t indexOfMin = begin;
16 for (size_t i = begin + 1; i < arr.size(); ++i) {
17 if (arr[i] < arr[indexOfMin]) {
18 indexOfMin = i;
19 } // else nothing
20 }
21
22 return indexOfMin;
23 }
24
25 static void SelectionSort(std::vector<int> &arr) {
26 for (size_t i = 0; i < arr.size(); ++i) {
27 size_t indexOfMin = GetIndexOfMin(arr, i);
28 if (i != indexOfMin) {
29 (void)swap(arr[i], arr[indexOfMin]);
30 } // else no need to swap
31 }
32 }
33
34 int main(int argc, char const *argv[]) {
35 std::vector<int> v {
36 6, 8, 9, 8, 7, 6, 5, 2, 0, -1
37 };
38
39 (void)SelectionSort(v);
40 for (int i: v) {
41 std::cout << i << "\t";
42 }
43 std::cout << "\n";
44
45 return 0;
46 }

最新文章

  1. 25、继续echarts实现中国地图
  2. Java集合---面试题
  3. 公共控件Listview
  4. Mysql常见报错解决方法
  5. trigger 触发器
  6. 关于scanf的几种处理方法
  7. Python实现类似switch...case功能
  8. hdu1664 bfs+余数判重
  9. delphi 中sql的语法规范
  10. [USACO15JAN]电影移动Moovie Mooving
  11. 201521123114 《Java程序设计》第2周学习总结
  12. js构建函数,点击按钮显示div,再点击按钮或其他区域,隐藏div
  13. 干货!分享一款windows下的磁盘分析神器。
  14. Java 集合系列(四)—— ListIterator 源码分析
  15. FAT文件系统规范v1.03学习笔记---3.根目录区之FAT目录项结构
  16. Arraylist集合遍历输出
  17. synchronized基础
  18. 修复python命令行下接收不到参数的问题
  19. Maven 构建
  20. 信号量 Linux函数 semget();semctl();semop();(转)

热门文章

  1. CMake配置跨平台项目踩的坑
  2. python存储xml格式数据
  3. ipmitool使用报错Could not open device at /dev/ipmi0 or /dev/ipmi/0 or /dev/ipmidev/0: No such file or directory
  4. Burpsuite入门之target模块攻防中利用
  5. history 添加 时间戳和ip,用户
  6. python的GIL全局解释器锁
  7. vi 快捷键/ctags
  8. mysql命令行如何执行sql脚本
  9. ASP.NET Core Web API通过中间件或UseExceptionHandler异常处理方法
  10. 创建SFTP用户并指定访问目录 Linux