十种排序算法(1) - 准备测试函数和工具

2023-10-30 19:38

本文主要是介绍十种排序算法(1) - 准备测试函数和工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.准备工作

我们先写一堆工具,后续要用,不然这些写在代码里可读性巨差

#pragma once
#include<stdio.h>//为C语言定义bool类型
typedef int bool;
#define false 0
#define true 1//用于交互a和b
inline void swap(int* a, int* b)
{/*int c = *a;*a = *b;*b = c;*/*a ^= *b;*b ^= *a;*a ^= *b;
}
//在ab之中取最小值
inline int min(int a, int b)
{return a < b ? a : b;
}
//在ab之中取最大值
inline int max(int a, int b)
{return a < b ? b : a;
}//检查越界异常,在编写排序算法时,容易出现下标越界,以此作为检查手段
inline int inRange(int x, int min, int max)
{int res = x >= min && x <= max;if (!res) printf("越界:%d  界限:[%d,%d]\n", x, min, max);return res;
}
//用于int的高效指数计算
inline int intpow(int a, int b)
{int r = 1;for (int i = 0; i < b; i++) r *= a;return r;
}//取得一个数在十进制下的位数
inline int getbitCount(int c)
{int bc = 0;do{bc++;} while (c = c / 10);return bc;
}//获取x的第c位
inline int getbit(int x, int c)
{// v = (x % 100) / 10^c-1return (x % intpow(10, c)) / intpow(10, c - 1);
}

测试函数

我们在sort函数里给出排序算法的实现

#define _CRT_SECURE_NO_WARNINGS#include<stdio.h>
#include<time.h>
#include<malloc.h>
#include<string.h>
#include "sort.h"//检查数组有序性
bool checkArraySort(int* nums, int numsSize, bool* upper)
{int resultA = true;for (int i = 0; i < numsSize - 1; i++){if (nums[i] > nums[i + 1]){//printf("无序数对下标:[%d,%d]\n", i, i + 1);resultA = false;}}if (resultA){*upper = true;return resultA;}int resultB = true;for (int i = 0; i < numsSize - 1; i++){if (nums[i] < nums[i + 1]){resultB = false;}}if (resultB){*upper = false;return resultB;}return false;
}
//输出数组元素
void printElements(int* nums, int count)
{for (int i = 0; i < count; i++){printf("%d", nums[i]);if (i < count - 1) printf(",");}printf("\n");
}
//随机生成数组
void randomArray(int* nums, int numsSize, int min, int max)
{srand(time(0));for (int i = 0; i < numsSize; i++){nums[i] = rand() % max - min + 1 + min;//printf("%d,", nums[i]);}}
int sort(int* arr, int size)
{quickSort(arr, size);
}int main()
{//常量:测试数据大小,随机最小值,随机最大值const int size = 10000;const int min = 0;const int max = 10000;//预分配测试数据,临时空间数组,随机备份数组int* arr = malloc(sizeof(int) * size);int* tempArr = malloc(sizeof(int) * size);int* copy = malloc(sizeof(int) * size);randomArray(arr, size, min, max);memcpy(copy, arr, sizeof(int) * size);//计时器clock_t start, end;start = clock();//排序sort(arr,size);end = clock();end -= start;bool upper;//测试数据有序性检查bool res = checkArraySort(arr, size, &upper);//输出排序报告printf("========排序测试报告========\n");printf("元素数量:%d\n", size);printf("排序后有序检查(%s):%d\n", upper ? "升序" : "降序", res);printf("排序耗时(tick):%d\n", (int)end);printf("排序耗时(ms):%f\n", (double)(end * 1000) / CLOCKS_PER_SEC);printf("排序耗时(s):%f\n", (double)end / CLOCKS_PER_SEC);printf("\n是否打印排序前后元素(IO操作可能产生较大的耗时)(Y/N)?\n");char option;int inputC = scanf("%c", &option);if (option == 'Y' || option == 'y'){printf("\n排序前:");printElements(copy, size);printf("排序后:");printElements(arr, size);}
}

在第一篇中,我们首先做这些内容,接下来我们就能心无旁骛的编写排序函数了。
下文的链接如果写完会继续贴在这里(代码写完了,原理还没写)
传送门:十种排序算法(1) xxx

在这里插入图片描述

这篇关于十种排序算法(1) - 准备测试函数和工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/310136

相关文章

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

Java Map排序如何按照值按照键排序

《JavaMap排序如何按照值按照键排序》该文章主要介绍Java中三种Map(HashMap、LinkedHashMap、TreeMap)的默认排序行为及实现按键排序和按值排序的方法,每种方法结合实... 目录一、先理清 3 种 Map 的默认排序行为二、按「键」排序的实现方式1. 方式 1:用 TreeM

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

使用python制作一款文件粉碎工具

《使用python制作一款文件粉碎工具》这篇文章主要为大家详细介绍了如何使用python制作一款文件粉碎工具,能够有效粉碎密码文件和机密Excel表格等,感兴趣的小伙伴可以了解一下... 文件粉碎工具:适用于粉碎密码文件和机密的escel表格等等,主要作用就是防止 别人用数据恢复大师把你刚删除的机密的文件恢

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

MySQL慢查询工具的使用小结

《MySQL慢查询工具的使用小结》使用MySQL的慢查询工具可以帮助开发者识别和优化性能不佳的SQL查询,本文就来介绍一下MySQL的慢查询工具,具有一定的参考价值,感兴趣的可以了解一下... 目录一、启用慢查询日志1.1 编辑mysql配置文件1.2 重启MySQL服务二、配置动态参数(可选)三、分析慢查

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

基于Python实现进阶版PDF合并/拆分工具

《基于Python实现进阶版PDF合并/拆分工具》在数字化时代,PDF文件已成为日常工作和学习中不可或缺的一部分,本文将详细介绍一款简单易用的PDF工具,帮助用户轻松完成PDF文件的合并与拆分操作... 目录工具概述环境准备界面说明合并PDF文件拆分PDF文件高级技巧常见问题完整源代码总结在数字化时代,PD