C语言四大排序算法实战

今天主要我练习了 C语言中的几种常见排序算法。包括以下内容、:

  1. 使用 qsort() 的标准库快速排序

  2. 手写冒泡排序

  3. 手写快速排序

  4. 插入排序

(一)四种算法区别

(二)使用 qsort() 函数的快速排序

cpp 复制代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h>

// qsort 的比较函数
int compare(const void* left, const void* right)
{
	return *(int*)left - *(int*)right;
}

int main()
{
	int arr1[10] = { 1,3,2,4,6,5,8,7,9,11 };

	// 使用 C 标准库的 qsort 进行排序
	qsort(arr1, 10, sizeof(int), compare);

	// 输出排序结果
	for (int i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	return 0;
}

(三)冒泡排序

cpp 复制代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h>

typedef int elemtype;
typedef struct sttable {
	elemtype* data;
	int len;
}sttable;

// 初始化结构体并随机生成数据
void init_ST(sttable& ST, int length)
{
	ST.len = length;
	ST.data = (elemtype*)malloc(sizeof(elemtype) * ST.len);
	srand(time(NULL));
	for (int i = 0; i < ST.len; i++)
	{
		ST.data[i] = rand() % 100;
	}
}

// 冒泡排序(双层循环,两两比较)
void bubble_ST(sttable& ST, int n)
{
	for (int i = 0; i < n - 1; i++)
	{
		for (int j = 0; j < n - i - 1; j++)
		{
			if (ST.data[j] > ST.data[j + 1])
			{
				// 使用异或实现交换
				ST.data[j] = ST.data[j] ^ ST.data[j + 1];
				ST.data[j + 1] = ST.data[j] ^ ST.data[j + 1];
				ST.data[j] = ST.data[j] ^ ST.data[j + 1];
			}
		}
	}
}

// 打印数组
void print_ST(sttable ST)
{
	for (int i = 0; i < ST.len; i++)
	{
		printf("%3d", ST.data[i]);
	}
	printf("\n");
}

int main()
{
	sttable ST;
	init_ST(ST, 10);
	print_ST(ST);
	bubble_ST(ST, 10);
	print_ST(ST);
	return 0;
}

(四)快速排序

cpp 复制代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h>

typedef int elemtype;
typedef struct Sstable {
	elemtype* data;
	int length;
}sstable;

// 初始化随机数组
void init_table(sstable& ST, int len)
{
	ST.length = len;
	ST.data = (elemtype*)malloc(sizeof(elemtype) * ST.length);
	srand(time(NULL));
	for (int i = 0; i < ST.length; i++)
	{
		ST.data[i] = rand() % 100;
	}
}

// 打印数组
void print_ST(sstable ST)
{
	for (int i = 0; i < ST.length; i++)
	{
		printf("%3d", ST.data[i]);
	}
	printf("\n");
}

// 划分函数:返回枢轴位置
int partition(int* p, int low, int high)
{
	int pivot = p[low];
	while (low < high)
	{
		while (low < high && p[high] >= pivot)
			high--;
		p[low] = p[high];
		while (low < high && p[low] <= pivot)
			low++;
		p[high] = p[low];
	}
	p[low] = pivot;
	return low;
}

// 快速排序递归实现
void quick_sort(int* p, int low, int high)
{
	if (low < high)
	{
		int pivot_pos = partition(p, low, high);
		quick_sort(p, low, pivot_pos - 1);
		quick_sort(p, pivot_pos + 1, high);
	}
}

int main()
{
	sstable ST;
	init_table(ST, 10);
	print_ST(ST);
	quick_sort(ST.data, 0, 9);
	print_ST(ST);
	return 0;
}

(五)插入排序(直接插入法)

cpp 复制代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h>

typedef int elemtype;
typedef struct Sstable {
	elemtype* data;
	int length;
}sstable;

// 初始化随机数组
void init_table(sstable& ST, int len)
{
	ST.length = len;
	ST.data = (elemtype*)malloc(sizeof(elemtype) * ST.length);
	srand(time(NULL));
	for (int i = 0; i < ST.length; i++)
	{
		ST.data[i] = rand() % 100;
	}
}

// 打印数组
void print_ST(sstable ST)
{
	for (int i = 0; i < ST.length; i++)
	{
		printf("%3d", ST.data[i]);
	}
	printf("\n");
}

// 直接插入排序
void insert_sort(int* p, int n)
{
	int i, j, interval;
	for (i = 1; i < n; i++)
	{
		interval = p[i]; // 保存待插入元素
		for (j = i - 1; j >= 0 && p[j] > interval; j--)
		{
			p[j + 1] = p[j]; // 向后移动
		}
		p[j + 1] = interval; // 插入到正确位置
	}
}

int main()
{
	sstable ST;
	init_table(ST, 10);
	print_ST(ST);
	insert_sort(ST.data, 10);
	print_ST(ST);
	return 0;
}
相关推荐
徐小夕@趣谈前端17 小时前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
问好眼17 小时前
【信息学奥赛一本通】1275:【例9.19】乘积最大
c++·算法·动态规划·信息学奥赛
Daydream.V17 小时前
逻辑回归实例问题解决(LogisticRegression)
算法·机器学习·逻辑回归
代码无bug抓狂人17 小时前
C语言之表达式括号匹配
c语言·开发语言·算法
不穿格子的程序员17 小时前
从零开始写算法——普通数组篇:缺失的第一个正数
算法·leetcode·哈希算法
学历真的很重要17 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程管理(详解版)
学习·职场和发展·系统架构·系统架构师
Nebula_g17 小时前
线程进阶: 无人机自动防空平台开发教程(更新)
java·开发语言·数据结构·学习·算法·无人机
rit843249918 小时前
基于MATLAB的环境障碍模型构建与蚁群算法路径规划实现
开发语言·算法·matlab
hoiii18718 小时前
MATLAB SGM(半全局匹配)算法实现
前端·算法·matlab
独自破碎E18 小时前
大整数哈希
算法·哈希算法