2022年数据库的算法参照 .pdf

上传人:Q****o 文档编号:28355093 上传时间:2022-07-27 格式:PDF 页数:7 大小:128.99KB
返回 下载 相关 举报
2022年数据库的算法参照 .pdf_第1页
第1页 / 共7页
2022年数据库的算法参照 .pdf_第2页
第2页 / 共7页
点击查看更多>>
资源描述

《2022年数据库的算法参照 .pdf》由会员分享,可在线阅读,更多相关《2022年数据库的算法参照 .pdf(7页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、交换排序法冒泡排序 | 鸡尾酒排序 | 奇偶排序 | Comb sort | Gnome sort | 快速排序选择排序法选择排序 | 堆排序插入排序法插入排序 | 希尔排序 | Tree sort | Library sort | Patience sorting归并排序法归并排序 | Strand sort非比较排序法基数排序 | 桶排序 | 计数排序 | 鸽巢排序 | Burstsort | Bead sort其他拓扑排序 | 排序网络 | Bitonic sorter | Batcher odd-even mergesort | Pancake sorting一、排序1. 冒泡法:使用

2、冒泡排序为一列数字进行排序的过程分类排序算法 数据结构 数组 最差时间复杂度O(n2)最优时间复杂度O(n)平均时间复杂度O(n2)最差空间复杂度O(n) total, O(1) auxiliary public static void sort(Comparable a) int N = a.length; for(int i=0;i0;j-) if(pareTo(aj-1)=-1) exchange(a,j,j-1); else 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1

3、 页,共 7 页 - - - - - - - - - break; 交换位置:public static void change(Comparable a,int from,int to) Comparable t = afrom; afrom = ato; ato = t; 判断是否已经有序:public static boolean isSorted(Comparable a) for(int i=1;ia.length;i+) if(pareTo(ai-1)=-1) return false; return true 2. 选择排序:名师资料总结 - - -精品资料欢迎下载 - - -

4、- - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 7 页 - - - - - - - - - 分类 排序算法 数据结构 数组 最差时间复杂度(n2) 最优时间复杂度(n2) 平均时间复杂度(n2)最差空间复杂度(n) total, O(1) auxiliary public static void change(Comparable a) int N = a.length; for(int i=0;iN;i+) int min = i; for(int j=i+1;jN;j+) if(paraeTo(amin)=-1) min

5、 = j; exchange(a,i,min); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 7 页 - - - - - - - - - 时间复杂度:比较的次数:(n-1)+(n-2)+.+1+0N2/2 交换的次数:N 时间复杂度是:N2/2+NN2/2 3. 插入排序:public static void change(Comparable a) int N = a.length; for(int i=0;i0;j-) if(pareTo(aj-1)=-1) ex

6、change(a,j,j-1); else break; 时间复杂度:比较次数: N2/4 交换次数: N2/4 时间复杂度是:N2/2 极端情况:名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 7 页 - - - - - - - - - 如果序列是排好序的,那么比较的次数是N-1 交换的次数是0 如果序列是随即的,那么比较的次数是N2/2 交换的次数是N2/2 4. 希尔排序 (shell sort) public static void sort(Comparable

7、 a) int N = a.length; int incs = 1391376,463792,198768,86961,33936,13776,4592,1968,861,336,112,48,21,7,3,1; for(int k=0;kincs.length;i+) int h = incsk; for(int i=h;i=h;j-=h) if(pareTo(aj-h) exchage(a,j,j-h); else break; 时间复杂度:n(3/2) 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - -

8、 - - - - - 第 5 页,共 7 页 - - - - - - - - - 5. 堆排序分类 排序算法 数据结构 数组 最差时间复杂度O( nlogn )最优时间复杂度O(nlogn )1平均时间复杂度 ( nlogn ) 最差空间复杂度O( n) total, O(1) auxiliary 6. 快速排序使用快速排序法对一列数字进行排序的过程分类排序算法 数据结构 Varies 最差时间复杂度( n2)最优时间复杂度( nlog n )平均时间复杂度( nlog n) comparisons 最差空间复杂度根据实现的方式不同而不同public class Quicksort publi

9、c static final Random RND = new Random(); private void swap(Object array, int i, int j) Object tmp = arrayi; arrayi = arrayj; arrayj = tmp; private int partition(Object array, int begin, int end, Comparator cmp) int index = begin + RND.nextInt(end - begin + 1); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - -

10、 - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 7 页 - - - - - - - - - Object pivot = arrayindex; swap(array, index, end); for (int i = index = begin; i end; + i) if (pare(arrayi, pivot) begin) int index = partition(array, begin, end, cmp); qsort(array, begin, index - 1, cmp); qsort(array, index + 1, end, cmp); public void sort(Object array, Comparator cmp) qsort(array, 0, array.length - 1, cmp); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 7 页 - - - - - - - - -

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 技术资料 > 技术总结

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com