<pre name="code" class="cpp">排序算法
排序有内部排序和外部排序
内部排序:数据记录在内存中排序
外部排序:因排序的数据很大,一次不能容纳全部 的排序记录,在排序的过程中需要访问外存
插入排序
将一个记录插入到已排序好的有序表中,从而得到一个新记录数增1的有序表。
即:先将序列的第1个记录看成是一个有序的子序列,然后从第2个记录逐个进行插入,直至整个序列有序为止。
要点:设立哨兵,作为临时存储和判断数组边界之用。
直接插入排序
基本思想: 1、首先把第一个元素单独看做一个有序序列,依次将后面的元素插入到该有序序列中;
2、插入的时候,将该元素逐个与前面有序序列中的元素进行比较,找到合适的插入位置,形成新的有序序列;
<p> 3、当有序序列扩大为整个原始序列的大小时,排序结束。</p>
void insert_sort1(int *arr,int len){int i;//从第1个元素开始循环执行插入for(i=1;i<len;i++){//将第i个元素分别与前面的元素比较,插入适当的位置if(arr[i]<arr[i-1]){//一直向左进行比较,直到插入到适当的位置int key=arr[i];int count=0;//用来记录key在与前面元素时向左移动的位置while(i>0&&key<arr[i-1]){arr[i]=arr[i-1];arr[i-1]=key;i--;count++;}//将待插入的数字定位到下一个元素//i+=count;}}}void
insert_sort2(int *arr,int len){int j,i;for(i=1;i<len;i++)for(j=i-1;j>=0&&arr[j]>arr[j+1];j--){//交换元素数值//由于不会出现自己与自己交换的情况//因此可以安全的用该交换方法arr[j]^=arr[j+1];arr[j+1]^=arr[j];arr[j]^=arr[j+1];}}void insert_sort3(int *arr,int len){int i,j;for(i=1;i<len;i++)if(arr[i]<arr[i-1]){//向前逐个比较,直到需要插入的地方int
key=arr[i];for(j=i-1;j>=0&&arr[j]>key;j--)arr[j+1]=arr[j];arr[j+1]=key;//插入key}}
折半插入排序
直接插入排序算法简单,且容易实现,当待排序的长度n很小时,是一种很好的排序方法,尤其当原始序列接近有序时,效率更好。如果待排序的长度n很大,则不适宜采用直接排序。这时我们可以考虑对其做些改进,我们可以从减少比较和移动的次数入手,因此可以采用折半插入排序,其思想类似于折半查找
void binsert_sort(int *arr,int len)
{
int i;
for(i=1;i<len;i++)
{
int low=0;
int high=i-1;
int key=arr[i];
//循环直至要插入的两个点之间
while(low<=high)
{
int mid=(low+high)/2;
if(key<arr[mid])
high=mid-1;
else
low=mid+1;
}
//循环结束low=high+1;并且low位置即为key要插入的位置
//从low到i的元素依次后移一位
int j;
for(j=i;j>low;j--)
arr[j]=arr[j-1];
//将key插入到low位置
arr[low]=key;
}
}
折半插入排序减少了比较的次数,但是元素的移动次数并没有减少。
希尔排序
又称“缩小增量排序”,也是一种属于插入排序类的方法
基本思想:
先将这个待排记录序列分割成为若干个子序列分别进直接插入排序,待整个序列中的记录
基本有序时,再对全体记录进行直接插入排序
void shell_insert1(int *arr,int len,int ader)
{
int i,k;
//循环对ader个子序列进行插入操作
for(k=0;k<ader;k++)
for(i=ader+k;i<len;i+=ader)//对一个子序列进行插入排序操作
{
//将第i个元素分别与前面的每隔ader个位置的元素进行比较,插入适当的位置
if(arr[i]<arr[i-ader])
{//一直向左进行比较,直到插入到适当的位置
int key=arr[i];
int count=0;//用来记录key在与前面元素比较时向左移动了几个ader长度; while(i>k&&key<arr[i-ader])
{
arr[i]=arr[i-ader];
arr[i-ader]=key;
i-=ader;
count++;
}
//将待插入的数定位到下一个元素,执行下一次插入排序
//因为后面还要执行i+=ader,所以这里回到原位置即可
i+=count*ader;
}
}
}
void shell_insert2(int *arr,int len,int ader)
{
int i,j,k;
//循环对ader个子序列各自进行插入排序
for(k=0;k<ader;k++)
for(i=ader+k;i<len;i+=ader)
for(j=i-ader;j>=k&&arr[j]>arr[j+ader];j-=ader)
{
//交换元素数值
arr[j]^=arr[j+ader];
arr[j+ader]^=arr[j];
arr[j]^=arr[j+ader];
}
}
void shell_insert2_1(int *arr,int len,int ader)
{
int i,j;
//交叉对ader个子序列进行插入排序
for(i=ader;i<len;i++)
for(j=i-ader;j>=0&&arr[j]>arr[j+ader];j-=ader)
{
//交换元素数值
//由于不会出现自己与自己交换的情况
//因此可以安全地用该交换方法
arr[j]^=arr[j+ader];
arr[j+ader]^=arr[j];
arr[j]^=arr[j+ader];
}
}
void shell_insert3(int *arr,int len,int ader)
{
int i,j,k;
//循环对ader个子序列各自进行插入排序
for(k=0;k<ader;k++)
for(i=ader+k;i<len;i+=ader)
if(arr[i]<arr[i-ader])
{
int key=arr[i];
for(j=i-ader;j>=k&&arr[j]>key;j-=ader)
arr[j+ader]=arr[j];
ader[j+ader]=key;
}
}
void shell_insert3_1(int *arr,int len,int ader)
{
int i,j;
//对ader子序列交叉进行插入排序
for(i=ader;i<len;i++)
if(arr[i]<arr[i-ader])
{
int key=arr[i];
for(j=i-ader;j>=0&&arr[j]>key;j-=ader)
arr[ader+j]=arr[j];
arr[j+ader]=key;
}
}
分享到:
相关推荐
实现以下常用的内部排序算法并进行性能比较:"直接插入排序"," 折半插入排序"," 2—路插入排序"," 表插入排序"," 希尔排序"," 起泡排序"," 快速排序"," 简单选择排序"," 树形选择排序"," 堆排序"," 归并排序"," 链式...
(1) 完成5种常用内部排序算法的演示,5种排序算法为:快速排序,直接插入排序,选择排序,堆排序,希尔排序; (2) 待排序元素为整数,排序序列存储在数据文件中,要求排序元素不少于30个; (3) 演示程序开始,...
本话题主要探讨六种内部排序算法:直接插入排序、希尔排序、冒泡排序、快速排序、选择排序以及堆排序。这六种排序算法各有优劣,适用于不同的场景,接下来我们将逐一进行详细阐述。 1. **直接插入排序**: 直接...
### 直接插入排序与希尔排序的比较 #### 一、概述 本篇文章将通过一组具体的数据集(8个整数)对直接插入排序(Direct Insertion Sort)和希尔排序(Shell Sort)这两种排序方法进行深入分析和比较。这两种排序...
本文将详细讲解六种经典的排序算法——合并排序、插入排序、希尔排序、快速排序、冒泡排序以及桶排序,并结合提供的文件名(sort.c、set.c、main.c、set.h、sort.h)推测出每个文件可能包含的代码实现。 1. **合并...
根据提供的文件信息,我们可以深入探讨几种经典的排序算法:冒泡排序、直接插入排序、快速排序以及希尔排序。这些算法在数据结构与算法课程中是非常重要的基础内容,它们各自有着独特的特性和应用场景。 ### 1. ...
下面将详细讲解这7种排序算法:快速排序、归并排序、插入排序、选择排序、冒泡排序、堆排序以及希尔排序。 1. **快速排序**:由C.A.R. Hoare提出的,采用分治策略。基本思想是选取一个基准元素,通过一趟排序将待...
本资源提供了七大经典排序算法的实现程序,包括快速排序、冒泡排序、选择排序、归并排序、插入排序、希尔排序和堆排序。下面将逐一详细介绍这些排序算法及其原理。 1. 快速排序:由C.A.R. Hoare提出,是一种采用...
本实验涉及了六种常见的排序算法:泡泡排序、直接插入排序、折半插入排序、希尔排序、直接选择排序,并且对每种排序算法进行了性能分析,包括统计执行时间、比较次数和交换次数。这些数据被保存在TXT文件中,便于...
本文将深入探讨C#中常见的四种排序算法:冒泡排序、选择排序、插入排序和希尔排序,以及它们的实现细节和应用场合。 首先,我们来看**冒泡排序**。冒泡排序是一种简单的交换排序方法,它通过不断比较相邻元素并交换...
希尔插入排序是希尔排序中最常见的实现方式之一,其基本步骤如下: - **初始化增量**:选择一个初始增量值(通常是数组长度的一半),然后不断减半直到增量为1。 - **分组排序**:根据当前增量值将数组分成若干组,...
本主题涵盖了六种经典的排序算法:希尔排序、堆排序、快速排序、简单选择排序、插入排序和冒泡排序。这些算法各有特点,适用于不同的场景,下面将逐一详细介绍。 1. **希尔排序**:希尔排序是由Donald Shell提出的...
这个压缩包文件“内部排序的主要算法及相关可实现程序.rar”包含了多种内部排序算法的实现,其中包括希尔排序(Hill Sort)、插入排序以及其他的经典排序算法,如选择排序、快速排序、堆排序和归并排序。下面将详细...
插入排序之希尔排序
【希尔排序】希尔排序是一种基于插入排序的快速排序算法,由希尔(Hoare)提出。它的主要思想是将待排序的元素按照一定的间隔分组,然后对每组进行插入排序,随着间隔逐渐减小,最后当间隔为1时,整个序列就是一个有序...
以下是关于"冒泡排序,选择排序,插入排序,希尔排序,堆排序,归并排序,快速排序"这七种常见排序算法的源码实现及相关知识点的详细解释: 1. **冒泡排序**:冒泡排序是一种简单的排序算法,它重复地遍历待排序的...
binary sort,二分法查找,binary search, 二分法排序,merge sort 混合排序,shell sort 希尔排序,insertion sort 插入排序。数据结构 data structure
这里我们主要探讨三种经典的排序算法:冒泡排序、插入排序以及希尔排序,这些都是基础且实用的排序算法,尤其对于初学者来说,理解它们的工作原理和实现过程非常有益。 **冒泡排序(Bubble Sort)** 冒泡排序是一种...
希尔排序(Shell Sort)是一种基于插入排序的快速排序算法,由Donald Shell于1959年提出。它的主要思想是将待排序的元素按照一定的间隔分组,对每组进行插入排序,然后逐渐减小间隔,直到间隔为1,此时整个序列视为...
最后,直接插入排序是最基础的排序算法之一,它的主要思想是将未排序的元素逐个插入到已排序的序列中。在`直接插入排序.cpp`中,我们可以看到如何遍历未排序部分,比较每个元素与已排序部分的元素,并找到合适的位置...