2008秋-计算机软件基础-快速排序
快速排序c语言源程序之一
快速排序c语言源程序之二
// 快速排序
// 使用递归调用来实现快速排序
// Author: eman lee
/*Quick Sort */
#include <stdio.h>
void quick_sort(int data[], int low, int high)
{
int i, j, pivot;
if (low < high)
{
pivot=data[low];
i=low;
j=high;
while(i<j)
{
while (i<j && data[j]>=pivot)
j--;
if(i<j)
data[i++]=data[j]; //将比枢轴记录小的记录移到低端
while (i<j && data[i]<=pivot)
i++;
if(i<j)
data[j--]=data[i]; //将比枢轴记录大的记录移到高端
}
data[i]=pivot; //枢轴记录移到最终位置
quick_sort(data,low,i-1);
quick_sort(data,i+1,high);
}
}
void main()
{
int i;
int data[9] = {54,38,96,23,15,72,60,45,83};
for(i=0;i<9;i++)
{
printf(" %d ",data[i]);
}
printf("\n");
quick_sort(data, 0, 8);
for(i=0;i<9;i++)
{
printf(" %d ",data[i]);
}
}
// 使用递归调用来实现快速排序
// Author: eman lee
/*Quick Sort */
#include <stdio.h>
void quick_sort(int data[], int low, int high)
{
int i, j, pivot;
if (low < high)
{
pivot=data[low];
i=low;
j=high;
while(i<j)
{
while (i<j && data[j]>=pivot)
j--;
if(i<j)
data[i++]=data[j]; //将比枢轴记录小的记录移到低端
while (i<j && data[i]<=pivot)
i++;
if(i<j)
data[j--]=data[i]; //将比枢轴记录大的记录移到高端
}
data[i]=pivot; //枢轴记录移到最终位置
quick_sort(data,low,i-1);
quick_sort(data,i+1,high);
}
}
void main()
{
int i;
int data[9] = {54,38,96,23,15,72,60,45,83};
for(i=0;i<9;i++)
{
printf(" %d ",data[i]);
}
printf("\n");
quick_sort(data, 0, 8);
for(i=0;i<9;i++)
{
printf(" %d ",data[i]);
}
}
快速排序c语言源程序之二
// 快速排序
// 使用递归调用来实现快速排序
// 10/21/2007
// Author: eman lee
/*Quick Sort */
#include <stdio.h>
struct node
{
int key;
int other;
};
typedef struct node SeqListNode;
//划分算法
int Partition(SeqListNode R[],int i,int j)
{
SeqListNode pivot=R[i];
while(i<j)
{
while(i<j&&R[j].key>=pivot.key)
j--;
if(i<j)
R[i++]=R[j];
while(i<j&&R[i].key<=pivot.key)
i++;
if(i<j)
R[j--]=R[i];
} //endwhile
R[i]=pivot;
return i;
}
//快速排序算法
void QuickSort(SeqListNode R[],int low,int high)
{
int pivotpos;
if(low<high)
{
pivotpos=Partition(R,low,high);
QuickSort(R,low,pivotpos-1);
QuickSort(R,pivotpos+1,high);
}
}
void main()
{
int i;
SeqListNode data[9] = {{54,11},{38,22},{96,33},{23,44},{15,55},{72,66},{60,77},{45,88},{83,99}};
for(i=0;i<9;i++)
{
printf(" %d ",data[i].key);
}
printf("\n");
QuickSort(data,0,8);
for(i=0;i<9;i++)
{
printf(" %d ",data[i].key);
}
}
// 使用递归调用来实现快速排序
// 10/21/2007
// Author: eman lee
/*Quick Sort */
#include <stdio.h>
struct node
{
int key;
int other;
};
typedef struct node SeqListNode;
//划分算法
int Partition(SeqListNode R[],int i,int j)
{
SeqListNode pivot=R[i];
while(i<j)
{
while(i<j&&R[j].key>=pivot.key)
j--;
if(i<j)
R[i++]=R[j];
while(i<j&&R[i].key<=pivot.key)
i++;
if(i<j)
R[j--]=R[i];
} //endwhile
R[i]=pivot;
return i;
}
//快速排序算法
void QuickSort(SeqListNode R[],int low,int high)
{
int pivotpos;
if(low<high)
{
pivotpos=Partition(R,low,high);
QuickSort(R,low,pivotpos-1);
QuickSort(R,pivotpos+1,high);
}
}
void main()
{
int i;
SeqListNode data[9] = {{54,11},{38,22},{96,33},{23,44},{15,55},{72,66},{60,77},{45,88},{83,99}};
for(i=0;i<9;i++)
{
printf(" %d ",data[i].key);
}
printf("\n");
QuickSort(data,0,8);
for(i=0;i<9;i++)
{
printf(" %d ",data[i].key);
}
}
分类:
[18] 数据结构与算法
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY