交换排序
冒泡排序
//冒泡排序
void BubbleSort1(ElemType A[], int n)
{
int i, j,flag;//flag为哨兵
for(i=0;i<n-1;i++)//i是控制多少个有序了void BubbleSort1(ElemType A[], int n)
{
flag = 0;
for (j = n - 1; j > i; j--)//内层控制比较,交换
{
if (A[j - 1] > A[j])
{
swap(A[j - 1], A[j]);
flag = 1;
}
}
if (0 == flag)
{
break;
}
}
}
快速排序
//快速排序 交换法
//有相同值不影响
int Partition(int* arr, int left, int right)
{
int k, i;
for (k = i = left; i < right; i++)
{
if (arr[i] < arr[right])
{
swap(arr[i], arr[k]);
k++;
}
}
swap(arr[k], arr[right]);
return k;
}
//递归实现
void QuickSort(ElemType A[], int low, int high)
{
if (low < high)
{
int pivotpos = Partition(A, low, high);//分割点左边的元素都比分割点小,右边的元素都比分割点大
QuickSort(A, low, pivotpos - 1);
QuickSort(A, pivotpos + 1, high);
}
}
全部代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<string.h>
typedef int ElemType;
typedef struct {
ElemType* elem;//存储元素的起始地址
int TableLen;//元素个数
}SSTable;
void ST_Init(SSTable& ST, int len)
{
ST.TableLen = len;
ST.elem = (ElemType*)malloc(sizeof(ElemType) * ST.TableLen);
int i;
srand(time(NULL));//随机数生成,每一次执行代码就会得到随机的10个数
for ( i = 0; i < ST.TableLen; i++)
{
ST.elem[i] = rand()%100;//生成的都是0-99
}
}
void ST_print(SSTable ST)
{
for (int i = 0; i < ST.TableLen; i++)
{
printf("%d ", ST.elem[i]);
}
printf("\n");
}
void swap(ElemType& a, ElemType& b)
{
ElemType tmp;
tmp = a;
a = b;
b = tmp;
}
//冒泡排序
void BubbleSort1(ElemType A[], int n)
{
int i, j,flag;//flag为哨兵
for(i=0;i<n-1;i++)//i是控制多少个有序了void BubbleSort1(ElemType A[], int n)
{
flag = 0;
for (j = n - 1; j > i; j--)//内层控制比较,交换
{
if (A[j - 1] > A[j])
{
swap(A[j - 1], A[j]);
flag = 1;
}
}
if (0 == flag)
{
break;
}
}
}
//快速排序
int Partition(int* arr, int left, int right)
{
int k, i;
for (k = i = left; i < right; i++)
{
if (arr[i] < arr[right])
{
swap(arr[i], arr[k]);
k++;
}
}
swap(arr[k], arr[right]);
return k;
}
//递归实现
void QuickSort(ElemType A[], int low, int high)
{
if (low < high)
{
int pivotpos = Partition(A, low, high);//分割点左边的元素都比分割点小,右边的元素都比分割点大
QuickSort(A, low, pivotpos - 1);
QuickSort(A, pivotpos + 1, high);
}
}
//冒泡排序与快速排序
int main()
{
SSTable ST;
ElemType A[10] = { 64,94,95,79,69,84,18,22,12,78 };
ST_Init(ST, 10);//初始化
//使用memcpy用确定的数组降低测试难度,排序算法写好之后注释即可
//memcpy(ST.elem, A, sizeof(A));//内存copy接口,当你copy整型数组或者浮点型的疏忽要用memcpy
ST_print(ST);
//BubbleSort1(ST.elem,10);//冒泡排序
QuickSort(ST.elem, 0, 9);//快速排序
ST_print(ST);
system("pause");
}
插入排序
直接插入排序
//插入排序,从小到大排序,升序
void InsertSort(ElemType A[], int n)
{
int i, j;
for (i = 2; i <= n; i++)//第0个元素是哨兵,第二个元素开始拿,往前面插
{
if (A[i] < A[i - 1])
{
A[0] = A[i];//放到暂存的位置,A[0]是暂存也是哨兵
for (j = i - 1; A[0] < A[j]; --j)
A[j + 1] = A[j];
A[j + 1] = A[0];
}
}
}
折半插入排序
//折半查找,插入排序
void MidInsertSort(ElemType A[], int n)
{
int i, j, low, high, mid;
for (i = 2; i <= n; i++)
{
A[0] = A[i];
low = 1; high = i - 1;//low就是有序序列的开始,high就是有序序列的结束
while (low <= high)//先通过二分查找找到待插入位置
{
mid = (low + high) / 2;
if (A[mid] > A[0])
high = mid - 1;
else
low = mid + 1;
}
for (j = i - 1; j > high + 1; --j)
A[j + 1] = A[j];
A[high + 1] = A[0];
}
}
希尔排序
步长一直按照约定的减小
//希尔排序
void ShellerSort(ElemType A[], int n)
{
int dk, i, j;
for (dk = n / 2; dk >= 1; dk = dk / 2)//步长变化,步长变化
{
for (i = dk + 1; i <= n; ++i) //以dk为步长进行插入排序
{
if (A[i] < A[i - dk])
{
A[0] = A[i];
for (j = i - dk; j > 0 && A[0] < A[j]; j = j - dk)
A[j + dk] = A[j];
A[j + dk] = A[0];
}
}
}
}
全部代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
typedef int ElemType;
typedef struct {
ElemType* elem;//整型指针
int TableLen;
}SSTable;
void ST_Init(SSTable& ST, int len)
{
ST.TableLen = len + 1;//实际上申请了11个元素的空间,有一个哨兵
//每次把要插入的数据放到哨兵的位置
ST.elem = (ElemType*)malloc(sizeof(ElemType) * ST.TableLen);
int i;
srand(time(NULL));
for (i = 0; i < ST.TableLen; i++)
{
ST.elem[i] = rand() % 100;//随机了11个数,但是第一个元素是没有用到的
}
}
void ST_print(SSTable ST)
{
for (int i = 0; i < ST.TableLen; i++)
{
printf("%3d ", ST.elem[i]);
}
printf("\n");
}
//插入排序,从小到大排序,升序
void InsertSort(ElemType A[], int n)
{
int i, j;
for (i = 2; i <= n; i++)//第0个元素是哨兵,第二个元素开始拿,往前面插
{
if (A[i] < A[i - 1])
{
A[0] = A[i];//放到暂存的位置,A[0]是暂存也是哨兵
for (j = i - 1; A[0] < A[j]; --j)
A[j + 1] = A[j];
A[j + 1] = A[0];
}
}
}
//折半查找,插入排序
void MidInsertSort(ElemType A[], int n)
{
int i, j, low, high, mid;
for (i = 2; i <= n; i++)
{
A[0] = A[i];
low = 1; high = i - 1;//low就是有序序列的开始,high就是有序序列的结束
while (low <= high)//先通过二分查找找到待插入位置
{
mid = (low + high) / 2;
if (A[mid] > A[0])
high = mid - 1;
else
low = mid + 1;
}
for (j = i - 1; j > high + 1; --j)
A[j + 1] = A[j];
A[high + 1] = A[0];
}
}
//希尔排序
void ShellerSort(ElemType A[], int n)
{
int dk, i, j;
for (dk = n / 2; dk >= 1; dk = dk / 2)//步长变化,步长变化
{
for (i = dk + 1; i <= n; ++i) //以dk为步长进行插入排序
{
if (A[i] < A[i - dk])
{
A[0] = A[i];
for (j = i - dk; j > 0 && A[0] < A[j]; j = j - dk)
A[j + dk] = A[j];
A[j + dk] = A[0];
}
}
}
}
int main()
{
SSTable ST;
ST_Init(ST, 10);//实际申请了11个元素空间
ST_print(ST);
//直接插入排序
//printf("\n直接插入排序:\n");
//InsertSort(ST.elem, 10);
//折半插入排序
//printf("\n折半插入排序:\n");
//MidInsertSort(ST.elem, 10);
printf("\n希尔插入排序:\n");
ShellerSort(ST.elem,10);
ST_print(ST);
system("pause");
}