1.冒泡排序法
int main()
{
int arr[10] = { 2,4,6,8,10,1,3,5,7,9 };
int sz = sizeof(arr) / sizeof(arr[0]);
int i = 0;
for (i = 0; i < sz - 1; i++)//i的取值a[0]~a[8],所以i < sz - 1
{
int j = 0;
for (j = i + 1; j < sz; j++)//j的取值a[1]~a[9],j < sz
{
if (arr[i]>arr[j])
{
int tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
}
}
}
for (i = 0; i < n; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
2.选择排序法
int main()
{
int arr[10] = { 2,4,6,8,10,1,3,5,7,9 };
int sz = sizeof(arr) / sizeof(arr[0]);
int i = 0;
for (i = 0; i < sz - 1; i++)
{
//min记录最小值的下标
int min = i;//假设开始比较的第一个数为最小值,往后的每个数与它比较
int j = 0;
for (j = i + 1; j < sz; j++)
{
if (arr[j] < arr[min])
{
min = j;//如果有一个数比最小数还小,那么它就是当下最小值。记录最小值下标。
}
}
//交换用原最小值与当下最小值交换
int tmp = arr[i];
arr[i] = arr[min];
arr[min] = tmp;
}
//打印
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
3.快速排序
//qsort - 库函数一个快速排序的函数
//可以排序任何数据类型
#include <stdlib.h>
#include <string.h>
//qsort函数的使用者提供这个函数
int cmp_int(const void* p1, const void* p2)
{
return *(int*)p1 - *(int*)p2;
}
void print_arr(int arr[], int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
printf("\n");
}
test1()
{
int arr[] = { 3,1,5,2,4,9,8,6,5,7 };
int sz = sizeof(arr) / sizeof(arr[0]);
//使用qsort来排序整型数组,这里就要提供一个比较函数,这个比较函数能够比较2个整数的大小
//qsort 默认是排成升序的
qsort(arr, sz, sizeof(arr[0]), cmp_int);
print_arr(arr, sz);
}
//测试qsort 排序结构体数据
struct Stu
{
char name[20];
int age;
};
//按照年龄来比较
int cmp_stu_by_age(const void* p1, const void* p2)
{
return ((struct Stu*)p1)->age - ((struct Stu*)p2)->age;
}
int cmp_stu_by_name(const void* p1, const void* p2)
{
return strcmp(((struct Stu*)p1)->name, ((struct Stu*)p2)->name);
}
void test2()
{
struct Stu s[] = { {"zhangsan", 30}, {"lisi", 25}, {"wangwu", 50} };
int sz = sizeof(s) / sizeof(s[0]);
//测试按照年龄来排序
//qsort(s, sz, sizeof(s[0]), cmp_stu_by_age);
//测试按照名字来排序
qsort(s, sz, sizeof(s[0]), cmp_stu_by_name);
}
void Swap(char* buf1, char* buf2, int width)
{
int i = 0;
for (i = 0; i < width; i++)
{
char tmp = *buf1;
*buf1 = *buf2;
*buf2 = tmp;
buf1++;
buf2++;
}
}
//假设排序为升序
//希望这个bubble_sort函数可以排序任意类型的数据
void bubble_sort(void* base, size_t num, size_t width,
int (*cmp)(const void* p1, const void* p2))
{
//要确定趟数
size_t i = 0;
for (i = 0; i < num - 1; i++)
{
int flag = 1;//假设已经有序了
//一趟冒泡排序的过程
size_t j = 0;
for (j = 0; j < num - 1 - i; j++)
{
//两个相邻的元素比较
//arr[j] arr[j+1]
if (cmp((char*)base + j * width, (char*)base + (j + 1) * width) > 0)
{
//交换
flag = 0;
Swap((char*)base + j * width, (char*)base + (j + 1) * width, width);
}
}
if (flag == 1)
{
break;
}
}
}
void test3()
{
int arr[] = { 3,1,5,2,4,9,8,6,5,7 };
int sz = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, sz, sizeof(arr[0]), cmp_int);
print_arr(arr, sz);
}
void test4()
{
struct Stu s[] = { {"zhangsan", 30}, {"lisi", 25}, {"wangwu", 50} };
int sz = sizeof(s) / sizeof(s[0]);
//测试按照年龄来排序
//bubble_sort(s, sz, sizeof(s[0]), cmp_stu_by_age);
//测试按照名字来排序
bubble_sort(s, sz, sizeof(s[0]), cmp_stu_by_name);
}
int main()
{
//test1();
//test2();
//test3();
test4();
return 0;
}
4.两个有序数列,合并为一个有序数列
#include<stdio.h>
#define M 20
#define N 20
int main()
{
int arr1[M] = { 2,4,6,8,10,12,14 };
int arr2[N] = { 1,3,5,7,9 };
int arr3[M+N] = { 0 };//合并后的数组
int m = 7; //记录arr1数组要排序的个数
int n = 5; //记录arr2数组要排序的个数
int i = 0;//遍历arr1
int j = 0;//遍历arr2
int k = 0;//遍历arr3
//有序排序数组(插入法)
while (i < m && j < n)//先比较前面元素个数相等的部分
{
if (arr1[i] < arr2[j])
{
arr3[k] = arr1[i];
i++;
k++;
}
else
{
arr3[k] = arr2[j];
j++;
k++;
}
}
if (i==m)//后比较剩余元素多出的部分
{
for (; j < n; j++)
{
arr3[k] = arr2[j];
k++;
}
}
if (j==n)
{
for (; i < m; i++)
{
arr3[k] = arr1[i];
k++;
}
}
//打印
for (k = 0; k < M+N; k++)
{
printf("%d ", arr3[k]);
}
return 0;
}