直接选择排序和直接插入排序类似,都将数据分为有序的区域和无序的区域。所不同的是直接插入排序是将无序区的第一个元素直接插入到有序区以形成一个更大的有序区,而直接选择排序是从无序区选一个最小的元素直接放到有序区的最后(其实是将找到的最小元素与已排序序列紧邻的元素交换,从而使得已排序序列增大1)。
~~~
void Swap(int &a, int &b) {
int tmp = a;
a = b;
b = tmp;
}
void SelectSort(int a[], int size) {
int i;
for (i = 0; i < size; ++i) {
int min_index = i;
int j;
for (j = i + 1; j < size; ++j)
if (a[j] < a[min_index])
min_index = j;
Swap(a[i], a[min_index]);
}
}
~~~
该排序算法用到了交换两个数的函数。参考[这里](http://blog.csdn.net/u013074465/article/details/44342629)查看面试题“不借助其他变量,交换两个数”
- 前言
- Josephus约瑟夫问题及其变种
- 链表的常见实现
- 二叉树遍历、插入、删除等常见操作
- 二叉堆的插入删除等操作C++实现
- 插入排序和希尔排序
- 堆排序
- 归并排序及其空间复杂度的思考
- 快速排序的几种常见实现及其性能对比
- 红黑树操作及实现
- 整数的二进制表示中1的个数
- 位操作实现加减乘除四则运算
- 冒泡排序的改进
- 直接选择排序
- 不借助变量交换两个数
- 基础排序算法总结
- AVL树(Adelson-Velskii-Landis tree)
- avl树的C++实现
- 动态规划之钢条分割
- hash函数的基本知识
- 动态规划:求最长公共子串/最长公共子序列
- 最长递增子序列
- 称砝码问题
- 汽水瓶
- 字符串合并处理(二进制位的倒序)
- 动态规划:计算字符串相似度
- m个苹果放入n个盘子
- 生成k个小于n的互不相同的随机数
- 栈和队列的相互模拟
- 字符串的排列/组合
- KMP(Knuth-Morris-Pratt)算法
- n个骰子的点数
- 位运算的常见操作和题目