网站设计与规划论文,网站开发详细报价,yy直播间,软广告经典案例希尔排序介绍希尔排序由希尔发明#xff0c;当一个序列的无序程度较低时#xff0c;那么使用插入排序的效率就会很快#xff0c;希尔排序的核心思想就是#xff0c;通过逐步缩小增量(步长)来逐步把一开始很无序的序列慢慢变得有序#xff0c;最后当增量为1时#xff0c;就…希尔排序介绍希尔排序由希尔发明当一个序列的无序程度较低时那么使用插入排序的效率就会很快希尔排序的核心思想就是通过逐步缩小增量(步长)来逐步把一开始很无序的序列慢慢变得有序最后当增量为1时就是一次典型的插入排序。实现typedef int ElementType; void ShellSort(ElementType A[], int N) { int i,j,Increment; ElementType tmp; for (IncrementN/2; Increment0; Increment/2) { for (iIncrement; iN; i) { tmp A[i]; for (ji; jIncrement; j-Increment) { if (tmp A[j-Increment]) { A[j] A[j-Increment]; }else { break; } } A[j] tmp; } } }假如有一个元素数量为11的乱序序列那么就可以得到11/255/222/11这三个增量。对序列进行增量为5的插入排序分别获得下标为(50),(61),(72),(83),(94),(10,5)这六组下标的跳跃步长为5的序列然后分别对这六组序列进行插入排序排完序后的整个数列的有序程度就会升高一些这样就可以提高之后进行直接插入排序的效率了。接着进行增量为2的插入排序分别获得下标为(2,0),(3,1),(4,2,0),(5,3,1),(6,4,2,0),(7,5,3,1),(8,6,4,2,0),(9,7,5,3,1),(10,8,6,4,2,0)这九组下标的跳跃步长为2的序列再分别对这九组序列进行插入排序排序完后整个序列的有序程度就很高了。看似这一轮的比较次数很多但其实还有个break语句其表示若第一次比较不交换时那就不进行后续的比较了例如(420)若下标为4和2的不需要交换那说明下标为420的就已经是有序了不需要再对20进行比较了。若下标为42的进行交换了那还得继续比较下标为4和0的元素。算法中第一个for循环得到增量矩阵第二个for循环获得各个分序列中的首元素的下标第三个for循环对各个分序列进行插入排序。分析希尔排序是不稳定排序其会把不同步长的分序列进行排序当相同元素被分到不同分序列中时可能会改变它们的相对位置。不同步长序列的时间复杂度不一样若为n/2n/4....1的步长的话那最坏的时间复杂度为O().若用Hibbard步长序列(-1),那时间复杂度为O().若用Sedgewick步长序列(混合序列9×-9×1和-3×1),那最坏的情况下时间复杂度被优化成O()了。堆排序介绍在之前的文章中介绍了堆这一数据结构得益于堆的特性其根节点始终是最大值(或最小值)我们可以不停的取堆的根节点元素然后按顺序排好这样就可以得到排好序的序列了。实现typedef int ElementType; #define LeftChild(i) (2*(i)1) void Swap(ElementType *a, ElementType *b) { ElementType temp *a; *a *b; *b temp; } void PercDown(ElementType A[],int i,int N) { int Child; ElementType Tmp; for (Tmp A[i];LeftChild(i)N;iChild) { Child LeftChild(i); if (Child!N-1 A[Child1]A[Child]) { Child; } if (TmpA[Child]) { A[i] A[Child]; }else { break; } } A[i] Tmp; } void HeapSort(ElementType A[],int N) { int i; for (iN/2;i0;i--) { PercDown(A,i,N); } for (iN-1;i0;i--) { Swap(A[0],A[i]); PercDown(A,0,i); } }得益于堆对应完全二叉树父子节点位置的数学关系我们可以通过对原始无序序列进行下滤操作从而将其转化成符合堆结构的数组。此时这个数组的第一个元素是整个序列的最大值把它和最后的元素进行交换这样整个序列中我们完成了最大元素的归位。然后在把除最后元素的其他所有元素进行下滤操作重新形成新堆再把第一个元素放到倒数第二个位置上这样就完成了第二个最大元素的归位循环往复就以从大到小的顺序完成了排序操作。分析堆排序是不稳定的当把栈顶元素和最后有个元素进行交换时可能会改变相同元素的相对位置。要进行n-1次交换每次交换都得重新通过下滤操作构建堆结构(该构建操作的时间复杂度为 O(LogN))所以一共是O(NLogN)。