美文网首页
算法排序小结

算法排序小结

作者: 饥人谷_一叶之秋 | 来源:发表于2018-01-28 15:19 被阅读0次

一.什么是算法?

高德纳在《计算机程序设计艺术》里对算法的归纳:

  1. 输入: 一个算法必须有零个或以上的输入量
  2. 输出: 一个算法应该有一个或以上输出量
  3. 明确性:算法的描述必须无歧义,实际运行结果是确定的
  4. 有效性: 必须在有效步骤内结束
  5. 有效性:又称可行性。能够被执行者实现

二.算法

  1. 冒泡排序
    (1)原理: 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。 走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

    (2)效果演示: 冒泡排序.gif
    (3)代码:
function sort(array){
  var i, j;
  for(i=0; i<array.length; i++){
    for(j=0; j<array.length-1-i; j++){
      if(array[j]<=array[j+1]){
         }else{
         swap(array, j, j+1)
         }
    }
  }
  return array;
}

function swap(array, a, b){
  var temp = array[a]
  array[a] = array[b]
  array[b] = temp
}

console.log(sort([3,5,38,44,15,36,26,27,2,46,4,19,47,50,48]))  //  [2, 3, 4, 5, 15, 19, 26, 27, 36, 38, 44, 46, 47, 48, 50]
  1. 选择排序
    (1)原理:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
    优点:选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。

    (2)效果演示: 选择排序.gif
    (3)代码:
function sort(array){
  var i
  var j
  var indexOfMin
  for(i=0; i<array.length; i++){
    indexOfMin = i
    for(j=i+1; j<array.length; j++){
      if(array[j]<array[indexOfMin]){
        indexOfMin = j
      }
    }
    if(indexOfMin !==i){
      swap(array, i, indexOfMin)
    }
  }
  return array;
}

function swap(array, a, b){
  var temp = array[a]
  array[a] = array[b]
  array[b] = temp
}

console.log(sort([2,44,38,5,47,15,36,26,27,3,46,4,19,50,48])) //[2, 3, 4, 5, 15, 19, 26, 27, 36, 38, 44, 46, 47, 48, 50]
  1. 插入排序
    (1)原理:提取第一个元素,后一个元素与前一个元素对比,如果前一个元素大于后一个元素则,后一个元素向前移动一格,移动后再与前一个元素对比,直到前一个元素小于后一个元素为止。

    (2)效果演示: 插入排序.gif
    (3)代码

function Sort(array) {
  function swap(array, i, j) {
    var temp = array[i];
    array[i] = array[j];
    array[j] = temp;
  }
  var length = array.length,
      i,
      j;
  for (i = 1; i < length; i++) {
    for (j = i; j > 0; j--) {
      if (array[j - 1] > array[j]) {
        swap(array, j - 1, j);
      } else {
        break;
      }
    }
  }
  return array;
}

console.log(Sort([5,8,20,20,31,44,21,37,50,28,45,28,38,32])) //[5, 8, 20, 20, 21, 28, 28, 31, 32, 37, 38, 44, 45, 50]
  1. 归并排序
    (1)原理:把原始数组分成若干子数组,对每一个子数组进行排序,继续把子数组与子数组合并,合并后仍然有序,直到全部合并完,形成有序的数组。

    (2)效果演示: 归并排序.gif
    (3)代码:
function Sort(array) {  
    var len = array.length;
    if(len < 2) {
        return array;
    }
    var middle = Math.floor(len / 2),
        left = array.slice(0, middle),
        right = array.slice(middle);
    return merge(Sort(left), Sort(right));
}
function merge(left, right)
{
    var result = [];
    while (left.length && right.length) {
        if (left[0] <= right[0]) {
            result.push(left.shift());
        } else {
            result.push(right.shift());
        }
    }
    while (left.length)
        result.push(left.shift());
    while (right.length)
        result.push(right.shift());
    return result;
}
console.log(Sort([14,44,27,10,11,5,45,25,48,23,22,14,19,17]))  //[5, 10, 11, 14, 14, 17, 19, 22, 23, 25, 27, 44, 45, 48]
  1. 快速排序
    (1)原理: 将第一个元素a依次与其他元素向对比,比a大的元素放在右边,比a小的放在左边。然后将左右两边分别选择一个a重复执行以上步骤,直到排完为止。

    (2)效果演示: 快速排序.gif
  2. 随机快速排序
    (1)原理:该原理与快速排序相似,不同的是选择a不一定必须是第一个元素,是可以随机取到的。

    (2)效果演示: 随机快速排序.gif
    (3)代码
function quickSort(array) {  
    if (array.length <= 1) {
        return array;
    }  
    var pivotIndex = Math.floor(array.length / 2);  
    var pivot = array.splice(pivotIndex, 1)[0];  
    var left = [];  
    var right = [];  
    for (var i = 0; i < array.length; i++) {    
        if (array[i] < pivot) {      
            left.push(array[i]);    
        } else {      
            right.push(array[i]);    
        }  
    }  
    return quickSort(left).concat([pivot], quickSort(right));
}
console.log(quickSort([44,40,40,31,30,36,22,49,6,48,16,49,19]))  //[6, 16, 19, 22, 30, 31, 36, 40, 40, 44, 48, 49, 49]

三.参考文章

前端笔记
常见算法

相关文章

  • 排序算法小结

    文章同步链接芒果浩明 排序算法小结 1、冒泡排序 冒泡排序(Bubble Sort)是一种比较简单的排序,思路是通...

  • 数据结构&算法

    常见排序算法小结如何判断一个单链表是否有环?程序员必须知道的10大基础实用算法及其讲解排序算法总结 校招常考算法J...

  • 排序算法(常见排序算法小结)

    排序算法经过了很长时间的演变,产生了很多种不同的方法。对于初学者来说,对它们进行整理便于理解记忆显得很重要。每种算...

  • 算法排序小结

    一.什么是算法? 高德纳在《计算机程序设计艺术》里对算法的归纳: 输入: 一个算法必须有零个或以上的输入量 输出:...

  • 排序算法的小结

    这里将列举知名度较高的十种算法,附上自己的理解和代码。 冒泡排序 选择排序 插入排序 希尔排序 归并排序 快速排序...

  • 快速排序算法小结

    ▼ 简介 快速排序(Quicksort)是对冒泡排序的一种改进。快速排序由C. A. R. Hoare在1962年...

  • 冒泡排序算法小结

    冒泡算法1: for(int i=0; i

  • 常见排序算法小结

    最近温习了一下之前学的七七八八的常见排序算法 快速排序 归并排序 插入排序 希尔排序 堆排序 位图排序 冒泡排序 ...

  • java实现快速排序、归并排序、希尔排序、基数排序算法...

    快速排序算法 归并排序算法 希尔排序算法 基数排序算法

  • web开发需要知道的几个算法

    算法分类 快速排序算法 深度优先算法 广度优先算法 堆排序算法 归并排序算法

网友评论

      本文标题:算法排序小结

      本文链接:https://www.haomeiwen.com/subject/ulkoaxtx.html