一.插入排序
算法描述:
- 从第一个元素开始,该元素可以认为已经被排序
- 取出下一个元素,在已经排序的元素序列中从后向前扫描
- 如果该元素(已排序)大于新元素,将该元素移到下一位置
- 重复步骤 3,直到找到已排序的元素小于或者等于新元素的位置
- 将新元素插入到该位置后
- 重复步骤 2~5
function insertSort(arr){
var temp;
for(var i = 0; i< arr.length; i++){
temp = arr[i];
for(var j = i; j> 0; j--){
if(temp < arr[j-1]){
arr[j] = arr[]j-1]
}else{
arr[j] = temp;
break;
}
}
}
return arr;
}
二.选择排序
算法描述:直接从待排序数组中选择一个最小(或最大)数字,放入新数组中。
编程思路:先假设第一个元素为最小的,然后通过循环找出最小元素,然后同第一个元素交换,接着假设第二个元素,重复上述操作即可。
function inserSort(arr){
var minIndex,minValue;
for(var i = 0; i<arr.length - 1; i++){
minIndex = i;
minValue = arr[minIndex];
for(var j = i+1; j<arr.length; j++){
if(arr[j] < minValue){
minIndex = j;
minValue = arr[minIndex];
}
}
var temp = arr[i];
arr[i] = minValue;
arr[minIndex] = temp;
}
return arr;
}
三.冒泡排序
算法描述:
- 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
- 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
- 针对所有的元素重复以上的步骤,除了最后一个。
- 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
function insertSort(arr){
for(var i = 0; i<arr.length; i++){
for(var j = i; j<arr.length; j++){
if(arr[j] < arr[j+1]){
var temp = arr[j];
arr[j] = arr[j+1];
arr[j + 1] = temp;
}
}
}
return arr;
}