C语言-排序和查找
一 冒泡排序:算法特点:两层循环外层控制排序的趟数,内存控制相邻元素两两比较的次数。n个数共需n-1趟,(i=1;i<n;i++)趟数=n-1-1+1,其中第j趟需要相邻元素两两比较的次数为n-j。可以按照升序也可以安排降序排序。其实还可以优化。
oid Bubblesort(int *p,int n)
{
int i,j,temp;
for(i = 1;i < n;i++)
{
for(j = 0;i < (n - j);j++)
{
if(p[j]< p[j+1])
{
p[j]= p[j] + p[j+1];
p[j+1]= p[j] - p[j+1];
p[j]= p[j] - p[j+1];
}
}
}
}
二 快速排序:有左起点和右终点,还有一个标准点(任选),先从右端开始寻找比标准小的值,再从左端选大于标准的值,然后将其交换,逐个进行这样的操作,知道前后两个指针相等此时记下该位置点并与标准点进行值交换,最终以标准为界,左端是小于标准点的一个序列,右边是大于标准值得序列,但这两个序列都是无序的。
然后分别对左边序列和右边序列进行函数递归调用重复上述过程。
void quicksort(int *p,int low,int high)
{
int slect_std;
int i,j;
slect_std = p[low];
i = low;
j = high;
while(i <= j)
{
while(p[slect_std] <= p[j] && (i<j))
j--;
while(p[slect_std] >= p[i] && (i<j))
i--;
if(i < j)
p[i] = p[i] + p[j];
p[j] = p[i] - p[j];
p[i] = p[i] - p[j];
}
p[i] = p[lown];
slect_std = p[i];
quicksort(p,low,i-1);
quicksort(p,i+1,high);
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?