(c语言)用冒泡排序模拟实现qsort()函数交换整数

#include<stdio.h>

int cmp(const void* x1, const void* x2)

{

return (*(int*)x1 - *(int*)x2);

}

void Swap(char* x, char* y, int width) //将两个数改为char*类型,每次只交换一个字节,直到将int*的四个字节全部交换一遍

{

int i = 0;

for (i = 0; i < width; i++)

{

char tmp = *x;

*x = *y;

*y = tmp;

x++;

y++;

}

}

sqort_moni(int* arr,int sz,int width, int (*cmp)(const void*, const void*))

{

int i,j;

for (i = 0; i < sz - 1; i++)

{

int flag = 1;

for (j = 0; j < sz - 1 - i; j++)

{

if (cmp((char*)arr + j * width, (char*)arr + (j + 1) * width )> 0) //返回值大于0,则说明x1>x2,需要顺序排列则要交换两个数

{

Swap((char*)arr + j * width, (char*)arr + (j + 1) * width, width);

flag = 0;

}

}

if (flag == 1) //如果循环一整遍之后都符合条件,则直接跳出循环

{

break;

}

}

}

int main()

{

int arr[10] = {9,8,7,6,5,4,3,2,1,0};

int sz = sizeof(arr) / sizeof(arr[0]);

sqort_moni(arr,sz,sizeof(arr[0]), cmp);

for (int i = 0; i < sz; i++)

{

printf("%d ",arr[i]);

}

return 0;

}

相关推荐
Dylan的码园1 分钟前
以二叉树问题为基础的递归调试学习(上)
java·学习·算法·leetcode·r-tree
少许极端5 分钟前
算法奇妙屋(九)-栈
java·数据结构·算法·
朱嘉鼎12 分钟前
KeilIDE背后的命令
c语言·嵌入式硬件·keilmdk
CoovallyAIHub23 分钟前
未来已来:从 CVPR & ICCV 观察 2025→2026 年计算机视觉的七大走向
深度学习·算法·计算机视觉
apcipot_rain1 小时前
CSP集训错题集 第八周 主题:基础图论
算法·图论
天选之女wow1 小时前
【代码随想录算法训练营——Day57(Day56周日休息)】图论——53.寻宝
算法·图论
文火冰糖的硅基工坊1 小时前
[人工智能-大模型-103]:模型层 - M个神经元组成的单层神经网络的本质
python·算法·机器学习
无语子yyds1 小时前
C++双指针算法例题
数据结构·c++·算法
仟濹2 小时前
「经典数字题」集合 | C/C++
c语言·开发语言·c++
Skrrapper2 小时前
【STL】set、multiset、unordered_set、unordered_multiset 的区别
c++·算法·哈希算法