首页 > 其他分享 >快速排序

快速排序

时间:2022-12-23 21:11:21浏览次数:30  
标签:typedef int elem high low SqList 排序 快速

本题要求实现快速排序的一趟划分函数,待排序列的长度1<=n<=1000。

函数接口定义:

1 int Partition ( SqList L, int low,  int high );

其中L是待排序表,使排序后的数据从小到大排列。
###类型定义:

1 typedef  int  KeyType;
2 typedef  struct 
3 {                      
4   KeyType *elem; /*elem[0]一般作哨兵或缓冲区*/                       
5   int Length;      
6 }SqList;

裁判测试程序样例:

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 typedef  int  KeyType;
 4 typedef  struct 
 5 {                      
 6   KeyType *elem; /*elem[0]一般作哨兵或缓冲区*/                     
 7   int Length;      
 8 }SqList;
 9 void  CreatSqList(SqList *L);/*待排序列建立,由裁判实现,细节不表*/ 
10 int Partition ( SqList  L,int low,  int  high );
11 void Qsort ( SqList  L,int low,  int  high );
12 int main()
13 {
14   SqList L;
15   int i;
16   CreatSqList(&L);
17   Qsort(L,1,L.Length);
18   for(i=1;i<=L.Length;i++)
19       printf("%d ",L.elem[i]);
20   return 0;
21 }
22 void Qsort ( SqList  L,int low,  int  high ) 
23 { 
24     int  pivotloc;
25     if(low<high)
26     {  
27         pivotloc = Partition(L, low, high ) ;
28         Qsort (L, low, pivotloc-1) ; 
29         Qsort (L, pivotloc+1, high );
30      }
31 }
32 /*你的代码将被嵌在这里 */

代码如下:

int Partition ( SqList  L,int low,  int  high ){
    L.elem[0]=L.elem[low];
    int l=low,r=high;
    while(l<r){
        while(r>l&&L.elem[r]>=L.elem[0]) r--;
        L.elem[l]=L.elem[r];
        while(l<r&&L.elem[l]<=L.elem[0]) l++;
        L.elem[r]=L.elem[l];
    }
    L.elem[l]=L.elem[0];
    return l;
}

 

标签:typedef,int,elem,high,low,SqList,排序,快速
From: https://www.cnblogs.com/psh888/p/17001643.html

相关文章

  • 堆排序
    本题要求实现堆排序中的筛选函数,待排序列的长度1<=n<=1000。函数接口定义:1voidHeapAdjust(HeapTypeH,ints,intm);其中L是待排序表,使排序后的数据从小到大排......
  • 冒泡排序
    冒泡排序只会操作相邻的两个数据。每次冒泡操作都会对相邻的两个元素进行比较,看是否满足大小关系要求。如果不满足就让它俩互换。一次冒泡会让至少一个元素移动到它应......
  • 快速滚动到顶部和底部的js方法
    //平滑的滚动到底部constscrollToBottom=(element)=>element.scrollIntoView({behavior:"smooth",block:"end"});//平滑的滚动到顶部constscrollToTo......
  • js:Object对象按照key的升序排序
    思路:js的Object对象类型,不能直接排序,不过Array是可以排序的将Object类型的key,转为Array排序,再将结果转为Object示例letdata={name:"tom",age:20,};consol......
  • 排序算法模板(更新中)
    快速排序#include<bits/stdc++.h>usingnamespacestd;constintN=1e6+10;intn;intq[N];voidposition(intq[],intl,intr){if(l>=r)ret......
  • 【JVS低代码】一分钟学会如何快速创建应用
    应用中心功能介绍在JVS角色中有“应用管理员”的角色,如果赋予该角色,则用户为应用管理员,应用管理员有进入应用配置中心的权限。创建空白应用:从模板创建应用:应用中心入口具备......
  • 基于posthgis 按照距离排序
    安装环境postsql需要安装拓展postgis使用dcokerversion:'3'services:postgis:image:mdillon/postgis:latestcontainer_name:postgisports:......
  • 快速认识WKT文本标记语言的格式
    WKT用于表示矢量的几何空间图形  点:POINT(11)线:LINESTRING(34,1050,2025)面:POLYGON((11,51,55,15,11),(22,23,33,32,22))多点:MULTIPOINT(3.55.6,4......
  • [datatable]排序时指定某列不可排序
    datatable是一个jquery扩展的表格插件。其提供了强大的表格功能。官方地址:http://www.datatables.net/ 在官方示例中,对于表格的是否可排序是在初始化中设置的一个值来决定......
  • Gridview排序与分页-不使用“DataSourceControl DataSource”的情况下如何分页和排序
    如果你在GridView控件上设置AllowPaging="true"orAllowSorting="true"而没有使用使用数据源控件DataSource(i.e.SqlDataSource,ObjectDataSource),运行则会出现下列......