zoukankan      html  css  js  c++  java
  • 各种排序算法分析总结(待整理))

    用过C语言中的qsort, 想知道qsort和他们的比较,那我告诉你,qsort和sort是一样的,因为他们采用的都是快速排序。从效率上看,以下几种sort算法的是一个排序,效率由高到低(耗时由小变大):

    partion
    stable_partition
    nth_element
    partial_sort
    sort
    stable_sort
    记得,以前翻译过Effective STL的文章,其中对如何选择排序函数总结的很好:
    若需对vector, string, deque, 或 array容器进行全排序,你可选择sort或stable_sort;
    若只需对vector, string, deque, 或 array容器中取得top n的元素,部分排序partial_sort是首选.
    若对于vector, string, deque, 或array容器,你需要找到第n个位置的元素或者你需要得到top n且不关系top n中的内部顺序,nth_element是最理想的;
    若你需要从标准序列容器或者array中把满足某个条件或者不满足某个条件的元素分开,你最好使用partition或stable_partition;
    若使用的list容器,你可以直接使用partition和stable_partition算法,你可以使用list::sort代替sort和stable_sort排序。若你需要得到partial_sort或nth_element的排序效果,你必须间接使用。正如上面介绍的有几种方式可以选择。
    总之记住一句话: 如果你想节约时间,不要走弯路, 也不要走多余的路! 

  • 相关阅读:
    iOS中循环引用的解除
    Block的循环引用详解
    Mac OS X下面 Node.js环境的搭建
    swift中闭包和OC的block的对比
    STL priority_queue
    优先使用map(或者unordered_map)的find函数而非algorithm里的find函数
    Insert Interval
    Integer Break
    Unique Binary Search Trees
    腾讯2016实习生笔试
  • 原文地址:https://www.cnblogs.com/icmzn/p/5929367.html
Copyright © 2011-2022 走看看