1 Star 1 Fork 0

build小春宝 / C_C++代码

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
回调函数编写qsort函数并进行浮点型数组排序.cpp 1.08 KB
一键复制 编辑 原始数据 按行查看 历史
#define _CRT_SECURE_NO_WARNINGS 1
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int cmp_float(const void* e1, const void* e2) { //αȽ
if ((*(float*)e1 > *(float*)e2) > 0)
return 1;
else if ((*(float*)e1 < *(float*)e2) > 0)
return -1;
return 0;
}
void swap(char* buff1, char* buff2, int width) {
int i = 0;
char k;
for (i = 0; i < width; i++) {
k = *buff1;
*buff1 = *buff2;
*buff2 = k;
buff1++;
buff2++;
}
}
void qsort(void* base, int num, int width, int(*cmp)(const void* e1, const void* e2)) {
int i = 0, j = 0;
for (i = 0; i < num - 1; i++) {
for (j = 0; j < num - 1 - i; j++) {
if ((cmp((char*)base + j * width, (char*)base + (j + 1) * width)) > 0)
swap((char*)base + j * width, (char*)base + (j + 1) * width, width);
}
}
}
int main() {
int i = 0;
float arr[] = { 10.0f,5.0f,8.0f,76.0f,955.0f,120.0f,74.0f };
int sz_float = sizeof(arr) / sizeof(arr[0]);
for (i = 0; i < sz_float; i++)
printf("%f\t", arr[i]);
printf("\n");
qsort(arr, sz_float, sizeof(arr[0]), cmp_float);
for (i = 0; i < sz_float; i++)
printf("%f\t", arr[i]);
return 0;
}
C++
1
https://gitee.com/build-xiaochunbao/c-language-code.git
git@gitee.com:build-xiaochunbao/c-language-code.git
build-xiaochunbao
c-language-code
C_C++代码
master

搜索帮助