【学习记录】C语言各个排序问题

(1)冒泡排序

void BubbleSort(int a[], int n, int order) {
//冒泡排序(a表示数组,n表示数组大小,order为0时从小到大排序,order为1时,从大到小排序)
	int i, j, temp;
	for (i = 0; i < n - 1; i++) {
		for (j = i; j < n; j++) {
			if (order == 0) {//从小到大
				if (a[i] > a[j]) {
					temp = a[j];
					a[j] = a[i];
					a[i] = temp;
				}
			}
			if (order == 1) {//从大到小
				if (a[i] < a[j]) {
					temp = a[j];
					a[j] = a[i];
					a[i] = temp;
				}
			}
		}
	}
}

(2)直接插入排序

void InsertSort(int a[], int n, int order) {
//直接插入排序(a表示数组,n表示数组大小,order为0时从小到大排序,order为1时,从大到小排序)
	int i, j;
	int temp;
	if (order == 0) {
		for (i = 0; i < n - 1; i++) {
			temp = a[i + 1];
			j = i;
			while (j > -1 && (temp < a[j])) {
				a[j + 1] = a[j];
				j--;
			}
			a[j + 1] = temp;
		}
	}
	if (order == 1) {
		for (i = 0; i < n - 1; i++) {
			temp = a[i + 1];
			j = i;
			while (j > -1 && temp > a[j]) {
				a[j + 1] = a[j];
				j--;
			}
			a[j + 1] = temp;
		}
	}
}

(3)希尔排序

void ShellSort(int a[], int n, int order) { //希尔排序
//希尔排序(a表示数组,n表示数组大小,order为0时从小到大排序,order为1时,从大到小排序)
	int span = n, i, j, k, temp = 0, l = 0;//span为循环排序的增量
	while (span = span / 2) {
		for (k = 0; k < span; k++) {
			for (i = k; i < n - span; i = i + span) {
				temp = a[i + span];
				j = i;
				if (order == 0) {
					while (j > -1 && temp < a[j]) {
						a[i + span] = a[j];
						j = j - span;
					}
				}
				if (order == 1) {
					while (j > -1 && temp > a[j]) {
						a[i + span] = a[j];
						j = j - span;
					}

				}
				a[j + span] = temp;
			}
		}
	}
}

(4)直接选择排序

void SelectSort(int a[], int n, int order) { //直接选择排序
//直接选择排序(a表示数组,n表示数组大小,order为0时从小到大排序,order为1时,从大到小排序)
	int i, j, max;
	int temp;
	for (i = 0; i < n - 1; i++) {
		max = i;
		for (j = i + 1; j < n; j++) {
			if (order == 0) {
				if (a[j] < a[max])
					max = j;
			}
			if (order == 1) {
				if (a[j] > a[max])
					max = j;
			}
		}


		if (max != i) {
			temp = a[i];
			a[i] = a[max];
			a[max] = temp;
		}
	}
}

(5)堆排序

void CreatHeap(int a[], int n, int h) {//调整非叶结点a[h]使之满足最大堆,n为数组a的元素个数
	int i, j, flag;
	int temp;
	i = h;                               //i为要建堆的二叉树根结点下标
	j = 2 * i + 1;                       //j为i的左孩子结点下标
	temp = a[i];
	flag = 0;
	//沿左右孩子中值较大者重复向下筛选
	while (j < n && flag != 1) {
		//寻找左右孩子结点中的较大者,j为其下标
		if (j < n - 1 && a[j] < a[j + 1])
			j++;
		if (temp > a[j])
			flag = 1;                     //标记结束筛选条件
		else {                            //否则把a[j]上移
			a[i] = a[j];
			i = j;
			j = 2 * i + 1;
		}
	}
	a[i] = temp;                           //把最初的a[i]赋予最后的a[j]
}

void InitCreatHeap(int a[], int n) {
//初始化为最大堆
	int i;
	for (i = (n - 2) / 2; i >= 0; i--)
		CreatHeap(a, n, i);
}

void HeapSort(int a[], int n, int order) { 
//堆排序(a表示数组,n表示数组大小,order为0时从小到大排序,order为1时,从大到小排序)
	int i;
	int temp;
	InitCreatHeap(a, n);                   //初始化为最大堆
	if (order == 0) {                      //当前最大堆个数每次递减1
		for (i = n - 1; i > 0; i--) {
			temp = a[0];
			a[0] = a[i];
			a[i] = temp;
			CreatHeap(a, i, 0);            //调整根结点满足最大堆
		}//注意:此时子二叉树根结点下标为0,子二叉树结点数为1
	}
	if (order == 1);
}

2022/5/22

以下是一个C语言拓扑排序排课程序的例子: ```c #include <stdio.h> #include <stdlib.h> #define MAX_VERTEX_NUM 100 // 最大顶点数 typedef struct ArcNode { // 边表结点 int adjvex; // 邻接点域,存储该顶点对应的下标 struct ArcNode *nextarc; // 链域,指向下一个邻接点 } ArcNode; typedef struct VNode { // 顶点表结点 int data; // 顶点信息 ArcNode *firstarc; // 边表头指针 } VNode, AdjList[MAX_VERTEX_NUM]; typedef struct { // 图 AdjList vertices; // 邻接表 int vexnum, arcnum; // 顶点数和弧数 } ALGraph; int *etv, *ltv; // 事件最早发生时间和最迟发生时间 int *stack; // 存储拓扑序列的栈 int top = -1; // 栈顶指针 int *indegree; // 存储各个顶点的入度 void CreateGraph(ALGraph *G) { // 创建AOV网 int i, j, k; ArcNode *p; printf("请输入顶点数和弧数:"); scanf("%d,%d", &G->vexnum, &G->arcnum); for (i = 0; i < G->vexnum; i++) { // 初始化邻接表 G->vertices[i].data = i; G->vertices[i].firstarc = NULL; } for (k = 0; k < G->arcnum; k++) { // 建立邻接表 printf("请输入弧头和弧尾:"); scanf("%d,%d", &i, &j); p = (ArcNode *)malloc(sizeof(ArcNode)); p->adjvex = j; p->nextarc = G->vertices[i].firstarc; G->vertices[i].firstarc = p; } } void TopologicalSort(ALGraph *G) { // 拓扑排序 int i, k, gettop; ArcNode *p; int count = 0; // 计数,记录当前已经输出的顶点数 top = -1; // 初始化栈 etv = (int *)malloc(G->vexnum * sizeof(int)); // 事件最早发生时间 for (i = 0; i < G->vexnum; i++) { etv[i] = 0; // 初始化为0 } stack = (int *)malloc(G->vexnum * sizeof(int)); // 存储拓扑序列的栈 indegree = (int *)malloc(G->vexnum * sizeof(int)); // 存储各个顶点的入度 for (i = 0; i < G->vexnum; i++) { // 初始化各个顶点的入度 indegree[i] = 0; } for (i = 0; i < G->vexnum; i++) { // 计算各个顶点的入度 for (p = G->vertices[i].firstarc; p; p = p->nextarc) { indegree[p->adjvex]++; } } for (i = 0; i < G->vexnum; i++) { // 将入度为0的顶点入栈 if (indegree[i] == 0) { stack[++top] = i; } } while (top > -1) { // 栈不为空 gettop = stack[top--]; // 出栈 printf("%d -> ", gettop); // 输出拓扑序列 count++; // 计数 for (p = G->vertices[gettop].firstarc; p; p = p->nextarc) { // 对gettop的每个邻接点的入度减1 k = p->adjvex; if (--indegree[k] == 0) { // 若入度减为0,则入栈 stack[++top] = k; } if (etv[gettop] + 1 > etv[k]) { // 更新各个事件最早发生时间 etv[k] = etv[gettop] + 1; } } } if (count < G->vexnum) { // 拓扑序列中顶点数小于G->vexnum,说明存在环 printf("Error: Graph has a cycle\n"); exit(0); } } int main() { ALGraph G; CreateGraph(&G); TopologicalSort(&G); return 0; } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值