常见排序介绍

直接插入排序

在插入第i个记录的时,R1,R2...已经排好序,这时将关键字R依次与R1...比较,从而找到应该插入的位置,插入位置以及其后的记录依次往后移动。
时间复杂度O(n^2)     空间复杂度O(1)

冒泡排序

首先将第一个记录的关键字和第二个记录的关键字进行比较,若为逆序,则交换这两个记录的值,然后比较第二个和第三个记录的关键字,以此类推,知道第n-1个记录和第n个记录比较过为止。上述为第一趟冒泡排序,其结果是关键字最大的记录被交换到第n个记录的位置,然后进行第二趟冒泡排序,对前n-1个记录进行同样的操作,其结果关键字次大的记录被交换到第n-1个记录的位置,最多进行n-1趟,所有的记录有序排列。
时间复杂度O(n^2)     空间复杂度O(1)

简单选择排序

通过n-i在关键字之间比较,从n-i-1个记录中选出关键字最小的记录,并和第i个记录进行交换,当i等于n时所有的记录有序排列
时间复杂度O(n^2)      空间复杂度O(1)

希尔排序

先将真个带排序记录分割成若干个子序列,然后分别进行直接插入排序,带真个序列的记录基本有序时,在对全体记录进行插入排序。
时间复杂度O(n^1.3)     空间复杂度O(1)

快速排序

用一组数组存储记录,附设两个指针i和j,他们的初值分别为指向第一个记录和最后一个记录,设枢纽记录的关键字为pivokey,则首先从j所指向位置起向前搜素,找到第一个关键字小于pivokey的记录与枢纽记录交换,然后从i所指向位置起向后搜索,找到第一个大于关键字pivokey的记录与枢纽记录相互交换,重复这个步骤知道i等于j
时间复杂度O(nlogn)~O(n^2)    空间复杂度O(logn)

堆排序

对一组待排序记录的关键字,首先安装堆的定义排成一个序列,从而可以输出堆顶最大关键字,然后将剩余的关键字再调整新堆,以便得到次打的堆顶。如此反复,指导排成有序序列。
时间复杂度O(nlogn)

归并排序

把n个记录的无序文件看成是由n个长度为1的有序文件组成的文件,然后两两进行归并,得到n/2个长度为2或1的有序文件,再两两归并,如此反复,直到最后形成n个记录的有序文件。
时间复杂度为O(nlogn)

基数排序

按照组成关键字的各个数位的值进行排序,他是分配排序的一种,在在该排序中把关键字K_i看成一个元组。然后一次对各元组低位到高位进行比较,直到最后排序所有的最高位,得到有序序列。
时间复杂度O(d(n+rd))
时间: 2024-08-28 14:05:24

常见排序介绍的相关文章

常见排序算法(java实现)

常见排序算法介绍 冒泡排序 代码: public class BubbleSort { public static void sort(int[] array) { int tValue; for (int i = 0; i < array.length; i++) { for (int j = i; j < array.length; j++) { if (array[i] > array[j]) { tValue = array[i]; array[i] = array[j]; ar

几种常见排序算法

几种常见排序算法 几种常见排序算法 写在前面 基础介绍 初级排序算法 selection sort选择排序 insertion sort插入排序 ShellSort希尔排序 shuffing不是排序算法 merge sort归并排序 Abstract in-place merge原地归并的抽象方法 Top-down mergesort自顶向下的归并排序 Bottom-up mergesort自底向上的归并排序 quicksort 三向切分的快速排序 Heapsort堆排序 总结和比较 命题 本文

【整理】常见排序算法及其时间复杂度总结

原文出处: 1. 白话经典算法系列之八 MoreWindows白话经典算法之七大排序总结篇 2. 面试常用算法总结--排序算法(java版) 3. 常见排序算法小结 本篇主要整理了冒泡排序,直接插入排序,直接选择排序,希尔排序,归并排序,快速排序,堆排序七种常见算法,是从上面三篇博文中摘抄整理的,非原创. 一.冒泡排序 主要思路是: 通过交换相邻的两个数变成小数在前大数在后,这样每次遍历后,最大的数就"沉"到最后面了.重复N次即可以使数组有序. 冒泡排序改进1: 在某次遍历中,如果没有

常见排序算法(一) MergeSort

算法思想灰常重要,常见的用到分治思想的算法包括快速排序,归并,二分搜搜,大整数乘法等(参考 http://blog.csdn.net/com_stu_zhang/article/details/7233761,归纳很到位) 简单用归并对一个数组排序 思路: 简单来说对一个数组,只要他的左右两部分都是有序的,那么简单合并就ok了,那么左右两部分可以进一步划分各自的左右两部分----明显就是要递归了 算法:归并排序 1. 将数组一分为二,subArray1 和subArray2 2. 归并排序sub

常见插值方法介绍

常见插值方法介绍 Inverse Distance to a Power(反距离加权 插值法)”. “Kriging(克里金插值法)”. “Minimum Curvature(最小曲率)”. “Modified Shepard's Method(改进谢别德法)”. “Natural Neighbor(自然邻点插值法)”. “Nearest Neighbor(最近邻点插值法)”. “Polynomial Regression(多元回归法)”. “Radial Basis Function(径向基函

常见排序算法(冒泡、选择、插入、快速、归并C++实现)

常见排序算法(冒泡.选择.插入.快速.归并C++实现) #include <iostream> using namespace std; // 冒泡排序 void bubbleSort (int data[], size_t size) { for (size_t i = 0; i < size - 1; ++i) { bool ordered = true; for (size_t j = 0; j < size - 1 - i; ++j) if (data[j+1] <

第六章 常见排序算法

上章回顾 二叉树的定义 树深度的定义 什么样的二叉树是满二叉树 中序遍历的规则 [email protected]:Kevin-Dfg/[email protected]:Kevin-Dfg/Data-Structures-and-Algorithm-Analysis-in-C.git 第六章 第六章 常见排序算法 常见排序算法 [email protected]:Kevin-Dfg/[email protected]:Kevin-Dfg/Data-Structures-and-Algorith

常见排序算法总结(java实现)

所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作.常见的排序算法有选择排序,插入排序,希尔排序,归并排序和快速排序 由于在排序的过程中不可避免的要涉及到比较和交换,所以将他们抽取为两个单独的函数,如下所示 //为了排序代码的通用性,这里假定待排序的元素实现了Comparable接口 private static boolean less(Comparable v ,Comparable w){ return v.compareTo(w)<0; } priva

ReactiveCocoa常见操作方法介绍/MVVM架构思想

1.ReactiveCocoa常见操作方法介绍. 1.1 ReactiveCocoa操作须知 所有的信号(RACSignal)都可以进行操作处理,因为所有操作方法都定义在RACStream.h中,因此只要继承RACStream就有了操作处理方法. 1.2 ReactiveCocoa操作思想 运用的是Hook(钩子)思想,Hook是一种用于改变API(应用程序编程接口:方法)执行结果的技术. Hook用处:截获API调用的技术. Hook原理:在每次调用一个API返回结果之前,先执行你自己的方法,