用js实现各种排序

1.快排

//新建数组递归,理解容易,性能差,不算真正意义上的快排
function quicksort(arr) {
  if(arr.length<=1) return arr;
  let left=[];
  let right=[];
  let num=arr[0];
  for(let i=1;i<arr.length;i++) {
    if(arr[i]>num) right.push(arr[i]);
    else left.push(arr[i])
  }
  return quicksort(left).concat(num,quicksort(right));
}


//标准版本
function partition(arr,low,high){
	let pivot=arr[low];
	while(low<high){
		while(low<high && arr[high]>=pivot){
			high--;
		}
		arr[low]=arr[high];
		while(low<high && arr[low]<=pivot){
			low++;
		}
		arr[high]=arr[low];
	}
	arr[low]=pivot;
	return low;
}

function quickSort(arr,low,high){
	if(low<high){
		let pivotPos=partition(arr,low,high);
		quickSort(arr,low,pivotPos-1);
		quickSort(arr,pivotPos+1,high);
	}
}

2.冒泡

function bubblesort(arr) {
  for(let i =0;i<arr.length;i++) {
    for(let j=i;j<arr.length;j++) {
      if(arr[i]>arr[j]){
        let temp=arr[i];
        arr[i]=arr[j];
        arr[j]=temp;
      }
    }
  }
}

3.选择排序

通过比较首先选出最小的一个数放在第一个位置,然后在其余的数中选出次小的数放在第二个位置,以此类推直到所有的数成为有序的序列

function selectsort(arr) {
  for(let i=0;i<arr.length;i++) {
    let min=i;
    for(let j=i;j<arr.length;j++){
      if(arr[min]>arr[j]){
        min=j;
      }
    }
    let temp=arr[i];
    arr[i]=arr[min];
    arr[min]=temp;
  }
}

4.插入排序
从第二个元素开始,将待排元素插入到前面已经排好序的序列中

function insersort(arr){
    for(let i=1;i<arr.length;i++){
        for(let j=i;j>0;j--){
            if(arr[j-1]>arr[j]){
                let temp=arr[j];
                arr[j]=arr[j-1];
                arr[j-1]=temp;               
            }
        }
    } 
    return arr;
}

在基数特别大的情况,且有上下限适用于基数排序和桶排序
5.基数排序
一个列表,列表按照顺序排列,每个列表项是一个链表。遍历数据,数据是多大就放在哪个列表项中,插入列表项的链表末尾,这样遍历完所有的数据,就得到了一个顺序的列表,列表每一项都是一样大数据的链表。
时间复杂度O(n)
6.桶排序(适用于数据分布比较均匀的情况)
类似于基数排序,如果每个桶都只能放一个数据,那就等于基数排序,如果每个桶能放一个区间的数据,就是桶排序。
每个桶都有个区间范围,别设置的太大。
桶和桶之间是顺序排放的,遍历数据,在哪个桶的范围内就放哪个桶里,最后再对每个桶进行排序。
桶排序的时间复杂度一般为 O(n + k),其中 n 是待排序元素的个数,k 是桶的数量。对于桶内排序,如果选择了高效的排序算法(如插入排序),时间复杂度接近 O(n),但实际性能还取决于数据分布和桶的数量。

### 回答1: 快速排序是一种分治算法,通常用于对数组进行排序。它的基本思想是:选择一个基准元素,通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。 下面是用 JavaScript 实现快速排序的示例代码: ``` function quickSort(arr) { if (arr.length <= 1) { return arr; } const pivotIndex = Math.floor(arr.length / 2); const pivot = arr.splice(pivotIndex, 1)[0]; const left = []; const right = []; for (let i = 0; i < arr.length; i++) { if (arr[i] < pivot) { left.push(arr[i]); } else { right.push(arr[i]); } } return quickSort(left).concat([pivot], quickSort(right)); } ``` 在这段代码中,我们首先判断数组的长度是否小于等于 1,如果是,则直接返回数组,否则继续执行排序。接下来,我们计算出数组的中间索引,并使用 `splice` 方法将这个元素从数组中取出,作为基准元素。然后我们遍历数组,将比基准元素小的元素放到左边的数组中,将比基准 ### 回答2: 快速排序是一种常用的排序算法,通过分治的思想对数组进行排序。使用JavaScript实现快速排序的步骤如下: 1. 选择一个基准元素(通常选择数组的第一个元素)。 2. 将数组分成两个子数组,小于基准元素的放在左边,大于基准元素的放在右边。 3. 对左右子数组分别进行递归调用快速排序。 4. 合并左右子数组和基准元素,得到排序后的数组。 下面是使用JavaScript实现快速排序的代码: ```javascript function quickSort(arr) { // 结束条件:当数组的长度小于等于1时,无需再进行排序 if (arr.length <= 1) { return arr; } // 选择一个基准元素 const pivot = arr[0]; const left = []; const right = []; // 将数组按照基准元素分成左右两个子数组 for (let i = 1; i < arr.length; i++) { if (arr[i] < pivot) { left.push(arr[i]); } else { right.push(arr[i]); } } // 对左右子数组进行递归调用快速排序,并合并左子数组、基准元素和右子数组 return quickSort(left).concat(pivot, quickSort(right)); } // 测试代码 const arr = [5, 2, 7, 3, 9, 1]; const sortedArr = quickSort(arr); console.log(sortedArr); ``` 这段代码实现了快速排序算法,首先选择数组的第一个元素作为基准元素,然后将数组按照基准元素的大小分成左右两个子数组,再对左右子数组进行递归调用快速排序,最后合并左子数组、基准元素和右子数组,返回排序后的数组。 ### 回答3: 快速排序是一种常用的排序算法,其基本思想是通过一趟排序将待排记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,然后再对这两部分记录进行排序,最终得到有序序列。 通过JavaScript实现快速排序算法的关键步骤如下: 1. 确定基准值:选取数组中任意一个元素作为基准值,通常选择第一个元素或最后一个元素。此处以选择第一个元素为例。 2. 分割数组:遍历数组,将小于基准值的元素放在左边,大于基准值的元素放在右边,相等的元素可以放在任意一边。 3. 递归排序:将左边和右边的子数组分别进行快速排序,直到每个子数组只含有一个元素。 4. 合并数组:将排好序的左边数组、基准值和排好序的右边数组依次合并起来,即得到最终的排序结果。 下面是一个使用JavaScript实现快速排序算法的示例代码: ```javascript function quickSort(arr) { if (arr.length <= 1) { return arr; } const pivotIndex = Math.floor(arr.length / 2); const pivot = arr.splice(pivotIndex, 1)[0]; const left = []; const right = []; for (let i = 0; i < arr.length; i++) { if (arr[i] < pivot) { left.push(arr[i]); } else { right.push(arr[i]); } } return quickSort(left).concat([pivot], quickSort(right)); } const array = [5, 3, 1, 2, 4]; const sortedArray = quickSort(array); console.log(sortedArray); // [1, 2, 3, 4, 5] ``` 以上是一个简单的使用JavaScript实现快速排序算法的示例,通过递归调用实现对子数组的排序,最终得到整个数组的排序结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值