一、冒泡排序
简单说一下冒泡排序过程,一个列表中有n个可排序元素,如果按升序(降序)排列,就需要进行n-1次循环完成排序(就像魔方拼好5个面自然就完全拼好了),每次循环按次两两比较,如果前一个数大于(小于)第二个数,两数进行交换,否则不交换,每循环1次,需要排序的元素个数减一。
【列表】[22, 13, 89, 44]
【第一次循环开始】[13, 22, 89, 44](22,13比较交换)
[13, 22, 89, 44](22,89比较不交换)
[13, 22, 44, 89](89,44比较交换)
【第一次循环结果】[13, 22, 44, 89]
【第二次循环开始】[13, 22, 44, 89](13,22比较不交换)
[13, 22, 44, 89](22,44比较不交换)
【第二次循环结果】[13, 22, 44, 89]
【第三次循环开始】[13, 22, 44, 89](13,22比较不交换)
【第三次循环结果】[13, 22, 44, 89]
js代码如下:
<script>
let arr = [1, 8, 2, 5, 7, 303, -5, 3, 9, 11, 20];
function bubbleSort(arr) {
for(let i = 0; i < arr.length - 1; i++) {
for (let j = 0; j < arr.length - 1 - i; j++) {
//两两比较
if (arr[j] > arr[j + 1]) {
// 交换两个值
let temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
return arr;
}
arr = bubbleSort(arr);
console.log(arr);
</script>
二、选择排序
简单说一下选择排序过程,一个列表中有n个可排序元素,如果按升序(降序)排列,就需要进行n-1次循环完成排序,第一循环选择列表中的最小(最大)值放到前面第一个位置,第二次循环选择列表除第一个以外的其他元素的最小值放到第二位,第三次循环以此类推……到结束。
js代码如下:
<script>
let arr = [1, 8, 2, 5, 7, 303, -5, 3, 9, 11, 20];
function xuanze(arr){
for (let i=0; i < arr.length; i++){
for (let j = i+1; j < arr.length; j++){
//找最值
if (arr[i] > arr[j]){
let temp = arr[j];
arr[j] = arr[i];
arr[i] = temp;
}
}
}
return arr;
}
arr = xuanze(arr);
console.log(arr);
</script>
三、插入排序
简单说一下插入排序的过程,一个列表中有n个可排序元素,如果按升序(降序)排列,从数列第一个元素开始,依次插入到列表的合适位置,第一个元素直接放到列表,第二个元素过来先和第一个元素比较大小,比第一个元素大(小)插到后面,比第一个元素小(大)插到前面,后面以此类推。
js代码如下:
<script>
let arr = [1, 8, 2, 5, 7, 303, -5, 3, 9, 11, 20];
function charu(arr){
for (let i = 0; i < arr.length; i++){
//依次进入
for (let j = 0; j < i+1; j++){
//找插入位置
if (arr[i+1] < arr[j]){
arr.splice(j, 0, arr[i+1]);
arr.splice(i+2, 1);
}
}
}
return arr;
}
arr = charu(arr);
console.log(arr);
</script>