冒泡排序、选择排序、快速排序、插入排序、希尔排序、归并排序、基数排序以及堆排序,桶排序

https://www.cnblogs.com/Glory-D/p/7884525.html

https://baike.baidu.com/item/%E4%BA%8C%E5%8F%89%E6%90%9C%E7%B4%A2%E6%A0%91/7077855?fr=aladdin

https://baike.baidu.com/item/%E4%BA%8C%E5%8F%89%E6%A0%91%E9%81%8D%E5%8E%86/9796049?fr=aladdin

https://www.cnblogs.com/gjmhome/p/11482019.html

下面是一些题。答案见

https://github.com/TouwaErioH/subjects/tree/master/C%2B%2B

 判断并证明:

1.

注意是随机快速排序

快速排序

有序(顺序或逆序的时候)或者元素都相同时n^2 (1+2+3+...+n-1)

随机化快速排序

元素相同时最差!(大雾)

因为是随机,所以与输入无关,都是nlogn

2.

5个数用比较排序,最差排几次?

https://blog.csdn.net/weixin_40113704/article/details/89509128

二叉树或信息论

log2(5!)=7

填空

1.

k叉树

https://blog.csdn.net/hacker_Dem_br/article/details/85286908

2.

选择排序和counting sort复杂度总是不变。

当已经排好序,bubble和(直接)插入排序最优。(答案是插入排序,不知道为什么,是冒泡排序的实现不同吗??)

大题:

1.

二叉树后序,前序遍历

2.

不平衡度最多为2的二叉树

画图容易理解。

类似递归。

每次用前一个高度的树作为根节点左侧的树,那么根节点右侧的树的节点数就确定了

总节点数为

1

2      1+1

3       1+2

5        1+3+(3-2)

9        1+5+(5-2)

...

xn=2*xn-1 + 1

3.

冒泡排序平均交换次数?

1. 每新加入一个数,不会影响前面n-1个数的交换次数。(bubble是稳定的)所以是f(n)=f(n-1)+(0+...+n-1)*(1/n)。故为n*(n-1)/4次交换

2.或者。考虑,n个数中任意两个数的关系为正确位置或错误位置。一共有n*(n-1)/2 组组合( C 2 N)。每组数错位不错位的概率相等为1/2,所以总的错误期望为n*(n-1)/4。

这样一次交换解决一次相邻两数的错位,一共n*(n-1)/4次交换

(比如a与b的顺序不受b与c的顺序影响)。

 给一个1-n的排列,与原来位置相同的数字的个数的期望大约是 1(如 n=5 则51324 与原来位置只有3是相同的)

直接计算也是可行的。n个数一共有n!种排列,现计算与原来位置数字相同的个数。这里用到全错位排列公式Dn=n!(1-1/1!+1/2!-1/3!+...+(-1)^n/n!),设有k个数字相同,则个数为k·C(n,k)·D(n-k),对k从1到n求和可得n!,故期望为1。

这个题要去算有几个相同的概率是比较难的,不过实际上有一个很简单的方法。在第1个位置,这个排列的第1个数字为1的概率为1/n,而期望是可加的,所以总共与原来位置相同的数字的个数的期望应该是1。也就是说不管是多少的数字,平均总是有一个数与顺序是相同的。

排序算法 以及HKU的一些数据结构 相关题目 以及 K叉树,二叉树 排列的更多相关文章

  1. JS实现常用排序算法—经典的轮子值得再造

    关于排序算法的博客何止千千万了,也不多一个轮子,那我就斗胆粗制滥造个轮子吧!下面的排序算法未作说明默认是从小到大排序. 1.快速排序2.归并排序3.冒泡排序4.选择排序(简单选择排序)5.插入排序(直 ...

  2. Python实现各种排序算法的代码示例总结

    Python实现各种排序算法的代码示例总结 作者:Donald Knuth 字体:[增加 减小] 类型:转载 时间:2015-12-11我要评论 这篇文章主要介绍了Python实现各种排序算法的代码示 ...

  3. 三种排序算法python源码——冒泡排序、插入排序、选择排序

    最近在学习python,用python实现几个简单的排序算法,一方面巩固一下数据结构的知识,另一方面加深一下python的简单语法. 冒泡排序算法的思路是对任意两个相邻的数据进行比较,每次将最小和最大 ...

  4. 用python实现各种排序算法

    最简单的排序有三种:插入排序,选择排序和冒泡排序.它们的平均时间复杂度均为O(n^2),在这里对原理就不加赘述了. 贴出源代码: 插入排序: def insertion_sort(sort_list) ...

  5. 十大排序算法总结(Python3实现)

    十大排序算法总结(Python3实现) 本文链接:https://blog.csdn.net/aiya_aiya_/article/details/79846380 目录 一.概述 二.算法简介及代码 ...

  6. 1T数据快速排序!十种经典排序算法总结

    1 冒泡排序 每次循环都比较前后两个元素的大小,如果前者大于后者,则将两者进行交换.这样做会将每次循环中最大的元素替换到末尾,逐渐形成有序集合.将每次循环中的最大元素逐渐由队首转移到队尾的过程形似&q ...

  7. 五种C语言非数值计算的常用经典排序算法

    摘要:排序是计算机的一种操作方法,其目的是将一组"无序"的记录序列调整为"有序"的记录序列,主要分为内部排序和外部排序. 排序 排序是计算机的一种操作方法,其目 ...

  8. JavaScript数据结构-2.排序算法

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 数据结构与算法——常用排序算法及其Java实现

    冒泡排序 原理:依次比较相邻的两个数,将小数放在前面(左边),大数放在后面(右边),就像冒泡一样具体操作:第一趟,首先比较第1个和第2个数,将小数放前,大数放后.然后比较第2个数和第3个数,将小数放前 ...

随机推荐

  1. Windows系统使用运行框运行程序

    配置步骤 1. 在非系统盘创建一个新文件夹,自定义名称.将需要使用运行框启动的程序或文件放入文件夹,并将其更改为自己容易记忆的名称 2. 创建环境变量 右击 "此电脑" → &qu ...

  2. 消息队列之rabbitmq学习使用

    消息队列之rabbitmq学习使用 1.RabbitMQ简介 1.1.什么是RabbitMQ? RabbitMQ是一个开源的消息代理和队列服务器,用来通过普通协议在完全不同的应用之间共享数据,Rabb ...

  3. Flask之路由系统

    路由系统 路由的两种写法 1.第一种方法: def index(): return render_template('index.html') app.add_url_rule('/index', ' ...

  4. 采用Sharding-JDBC解决分库分表

    源码:Sharding-JDBC(分库分表) 一.Sharding-JDBC介绍 1,介绍 Sharding-JDBC是当当网研发的开源分布式数据库中间件,从 3.0 开始Sharding-JDBC被 ...

  5. JVM(七)字符串详解

     常量池: 我们前面也一直说常量池有三种: 1:class文件中的常量池,前面我们解析class文件的时候解析的就是,这是静态常量池.在硬盘上. 2:运行时常量池.可以通过HSDB查看,是Instan ...

  6. 一文告诉你Java日期时间API到底有多烂

    前言 你好,我是A哥(YourBatman). 好看的代码,千篇一律!难看的代码,卧槽卧槽~其实没有什么代码是"史上最烂"的,要有也只有"史上更烂". 日期是商 ...

  7. OIer 生涯绊脚石

    字符串 哈希进制搞质数 \({\color{OrangeRed}{KMP}}\) 数组别开太大,否则 \({\color{Gold}{TLE}}\) 没有必要 \({\color{Cyan}{strl ...

  8. 最简单直接地理解Java软件设计原则之依赖倒置原则

    理论性知识 定义 依赖倒置原则,Dependence Inversion Principle (DIP) 高层模块不应该依赖低层模块.二者都应该依赖其抽象. 抽象不应该依赖细节,细节应该依赖抽象. 针 ...

  9. tp5项目部署Linux环境后无法访问解决

    一.编辑fastcgi.conf文件 vim /www/server/nginx/conf/fastcgi.conf 二.添加代码 fastcgi_param PHP_ADMIN_VALUE &quo ...

  10. 五:SpringBoot-多个拦截器配置和使用场景

    SpringBoot-多个拦截器配置和使用场景 1.拦截器简介 1.1 拦截器中应用 2.拦截器用法 2.1 编写两个拦截器 2.1.1 OneInterceptor 拦截器 2.1.2 TwoInt ...