冒泡排序
/**
* 2021.08.04
*bubbleSort
* @param nums
* @type {number[]}
* @return {*}
* @type {number[]}
* by 余白
*/
let nums=[1,75,4,5,9,4,7,3,0,-8,-9];
function bubbleSort (nums) {
for (let i=1;i<nums.length;++i){
for (let j=0;j<nums.length-i;++j){
nums[j] > nums[j+1] ? [nums[j],nums[j+1]] = [nums[j+1],nums[j]] : {};
}
}
return nums;
}
nums=bubbleSort(nums);
console.log(nums);
快速排序
/**
* 2021.08.04
* quickSort
* @param nums
* @type {number[]}
* @return {*}
* @type {number[]}
* by 余白
*/
let nums=[1,75,4,5,9,4,7,3,0,-8,-9];
function quickSort (nums){
if (nums.length<=1){
return nums;
}
const middleIndex = Math.floor(nums.length/2);
const middleValue = nums.splice(middleIndex,1)[0];
let leftNums=[],rightNums=[];
for (let i=0;i<nums.length;++i){
nums[i] < middleValue ? leftNums.push(nums[i]) :rightNums.push(nums[i]);
}
return quickSort(leftNums).concat(middleValue,quickSort(rightNums));
}
nums=quickSort(nums);
console.log(nums);
插入排序
let nums=[1,75,4,5,9,4,7,3,0,-8,-9];
for (let i=1;i<nums.length;++i){
for (let j=i;j>0;--j){
nums[j] < nums[j-1] ? [nums[j],nums[j-1]]=[nums[j-1],nums[j]] : {};
}
}
console.log(nums);
选择排序
let nums=[1,75,4,5,9,4,7,3,0,-8,-9];
/**
*selectSort
* @param nums
* @return {*}
*by 余白
*/
const selectSort = function (nums) {
let len=nums.length;
for (let i=0; i<len-1; ++i) {
for (let j = i + 1; j < len; ++j) {
if (nums[j] < nums[i]) {
[nums[i], nums[j]] =[nums[j], nums[i]];
}
}
}
return nums;
}
nums=selectSort(nums);
console.log(nums);