请用js写一个快速排序
时间: 2023-09-07 17:05:06 浏览: 113
js快速排序
### 回答1:
好的,以下是 JavaScript 中的快速排序算法的实现:
```
function quickSort(arr) {
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));
}
```
该代码中实现了快速排序的基本思路,即通过递归地对数组的两个子序列分别排序,最终将子序列合并在一起得到最终的排序结果。
### 回答2:
快速排序是一种常用的排序算法,基本思想是通过一趟排序将待排序的数据分割成两部分,其中一部分的所有数据都比另一部分的所有数据都小,然后再按此方法对这两部分数据分别进行快速排序,递归地进行此过程,直至整个序列有序。
以下是用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 arr = [5, 3, 1, 2, 4];
const sortedArr = quickSort(arr);
console.log(sortedArr); // 输出 [1, 2, 3, 4, 5]
```
该代码实现了一个名为quickSort的函数,它接受一个数组参数arr,并返回一个经过快速排序的新数组。首先,它判断数组长度是否小于等于1,如果是,则直接返回该数组。如果不是,则选择数组中间位置的数作为基准值pivot,并将其从原数组中删除。接下来,遍历原数组,将小于pivot的数放入新数组left中,将大于等于pivot的数放入新数组right中。最后,通过递归调用quickSort函数对新数组left和right分别进行快速排序,并将结果与pivot拼接返回。
以上代码是一个简单的应用实例,你可以通过将不同的数组作为参数传入quickSort函数来对不同的数据集进行排序。
### 回答3:
快速排序是一种常用的排序算法,其思想是选择一个基准元素,将数组分成两个子数组,其中一个子数组的元素都小于基准元素,另一个子数组的元素都大于基准元素,然后对这两个子数组递归地进行快速排序。
下面是使用JavaScript编写的快速排序代码:
```
function quickSort(arr) {
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, 3, 8, 4, 2, 1, 9, 7, 6];
console.log(quickSort(arr)); // [1, 2, 3, 4, 5, 6, 7, 8, 9]
```
上述代码中,`quickSort`函数接受一个数组作为输入,并返回排序后的数组。首先,函数判断数组的长度是否小于等于1,如果是,则直接返回该数组。否则,选择数组的第一个元素作为基准元素。然后遍历数组的其余元素,将小于基准元素的元素放入`left`数组,将大于基准元素的元素放入`right`数组。最后,使用递归对`left`和`right`数组进行快速排序,并将结果与基准元素连接起来,即可得到最终的排序结果。
以上代码可以在浏览器的开发者工具中使用,或者使用Node.js运行。
阅读全文