排序算法:
我们已经知道有一些常见的排序算法,如冒泡排序,选择排序, 插入排序, 归并排序,快速排序和堆排序。下面我们逐个地分析并编写相关代码。
首先在排序之前,我们需要先创建一个数组来表示待排序和搜索的数据结构以及数组操作中最常见的交换位置函数swap。代码如下:
function ArrayList() {
var array = [];
this.insert = function (item) {
array.push(item);
};
this.toString = function () {
return array.join();
}
var swap = function (array, index1, index2) {
var aux = array[index1];
array[index1] = array[index2];
array[index2] = aux;
}
}
下面逐个地分析各种排序算法:
冒泡排序:顾名思义,冒泡排序是比较两个相邻的项,如果第一个比第二个大,则交换它们。元素项向上移动至正确的顺序,就好像气泡升至表面一样。代码如下:
this.bubbleSort = function () {
var length = array.length;
for (var i = 0; i < length; i++) {//控制数组中排序的轮数
for (var j = 0; j < length - 1; j++) {
if (array[j] >= array[j + 1]) {
swap(array, j, j + 1);
}
}
}
};
我们注意到冒泡算法执行到外循环的第二轮的时候,前两位数字其实已经是排好序的,而在后续比较中,它们还进行着比较,这是不必要的,所有有了一种改进的冒泡算法,代码如下:
this.modifiedBubbleSort = function () {
var length = array.length;
for (var i = 0; i < length; i++){
for (var j =0 ;j < length-1-i; j++){
if (array[j] >= array[j+1]){