zoukankan      html  css  js  c++  java
  • [Algorithms] Quicksort algorithm using TypeScript

    Quicksort (also called partition sort and pivot sort) is arguably the most used sorting algorithm. It is the one commonly implemented internally in language runtimes. In this lesson we cover the quick sort algorithm, why is it called quick and how to implement it using TypeScript / JavaScript.

    export function quickSort(array) {
      array = [...array];
      partition(array, 0, array.length);
      return array;
    }
    
    function partition(array, start, end) {
      const length = end - start;
      if (length <= 1) return;
    
      // select the pivot
      const pivotIndex = start + Math.floor(Math.random() * length);
      // move the pivot to the beginning of the array
      [array[start], array[pivotIndex]] = [array[pivotIndex], array[start]];
      // get the pivot value
      const pivot = array[start];
      // get the pivot index
      let pivotRank = start;
      // loop thought the array, swap every number each is smaller
      // than the pivor
      for (let index = start + 1; index < end; index++) {
        if (array[index] < pivot) {
          // increase the rank poisition first
          pivotRank++;
          // swap the current number and rand poisition
          [array[index], array[pivotRank]] = [array[pivotRank], array[index]];
        }
      }
      // move the pivot to the pivotRank position
      if (pivotRank !== start) {
        [array[start], array[pivotRank]] = [array[pivotRank], array[start]];
      }
    
      partition(array, start, pivotRank);
      partition(array, pivotRank + 1, end);
    }
    
    const test = [5, 1, 8, 7, 4, 3, 6, 9];
    const res = quickSort(test);
    
    document.write(res);

     Simpfily way:

    function quickSort (array) {
    
        if (array.length <= 1) {
            return array;
        }
    
        let pivotIndex = 0;
        let pivot = array[pivotIndex];
    
        let less = []
        let greater = []
    
        for (let i in array) {
            if (i != pivotIndex) {
                array[i] > pivot ? greater.push(array[i]): less.push(array[i]);
            }
        }
    
        return [
            ...quickSort(less),
            pivot,
            ...quickSort(greater)
        ]
    }
    
    console.log(quickSort([6, 5, 4, 3, 2, 1, 7,9, 8]))

  • 相关阅读:
    左边定宽, 右边自适应方案
    C3 Transitions, Transforms 以及 Animation总结
    ES6中的Rest参数和默认参数
    Vue项目搭建流程 以及 目录结构构建
    在vue组件的stylus样式总 取消search类型的input按钮中默认样式
    JS与JQ绑定事件的几种方式.
    `<img>`放到`<div>`中底部出现空隙 以及解放方案.
    总结
    一道简单的编程题_ 关于定时器.
    mybatis-resultType和resultMap
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6799983.html
Copyright © 2011-2022 走看看