zoukankan      html  css  js  c++  java
  • 五分钟学算法之经典算法题 :排序算法(某东算法工程师比赛)

    题目描述

    已知数据表 A 中每个元素距其最终位置 不远 ,为了节省时间,应该采取的算法是()

    A、直接选择排序

    B、直接插入排序

    C、堆排序

    D、快速排序

    题目分析

    我们在之前学习 希尔排序 算法的时候提及到,希尔排序进行到一定阶段(每个元素距离其最终位置不远时)一般都使用 插入排序 来收尾。

    如果知道这个很容易知道答案选 B 。

    我们也可以通过分析这四个选项的时间复杂度来做判断。

    选择排序:对于 n 个元素,每次都需要遍历 n 次(与元素偏移位置没有什么关系),时间复杂度为 O(n2)

    插入排序:对于 n 个元素,如果每个元素距离其最终位置平均偏移 c 个单位,则每次比较 c 次,一共比较 n 趟,时间复杂度为 O(cn)。

    堆排序:对于 n 个元素,使用堆排序无论元素的位置如何排放时间复杂度都是 O(nlog(n))。

    快速排序:对于 n 个元素,即使每次选定的标定点很合适,它的最好时间复杂度也是 O(nlog(n))。

    当然,如果你熟悉它们的最好情况下的时间复杂度也是能立马得出答案的。

    更多内容

    你可以在电脑端访问我的个人博客下的专题 经典算法题 来阅读更多相关的面试题。

    专题地址:https://www.cxyxiaowu.com/jingdiansuanfati

  • 相关阅读:
    三元表达式、列表推导式、生成器表达式、递归、匿名函数
    nonlocal关键字、装饰器
    函数嵌套、作用域、闭包
    实参和形参
    函数基础
    文件操作
    字符编码
    推荐一个纯JavaScript编写的图表库——Highcharts
    推荐web 前端代码的编辑分享平台——RunJS
    了解腾讯
  • 原文地址:https://www.cnblogs.com/fivestudy/p/11738176.html
Copyright © 2011-2022 走看看