全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C语言数据结构 快速排序实例详解

C语言数据结构 快速排序实例详解

一、快速排序简介

快速排序采用分治的思想,第一趟先将一串数字分为两部分,第一部分的数值都比第二部分要小,然后按照这种方法,依次对两边的数据进行排序。

二、代码实现

#include <stdio.h>


/* 将两个数据交换 */
void swap(int* Ina , int* Inb)
{
  int temp = *Ina;
  *Ina = *Inb;
  *Inb = temp;
}

/* 进行一趟的快速排序,把一个序列分为两个部分 */
int getPartion(int* InArry,int InBegin,int InEnd)
{
  /* 刚开始的分隔线是第一个 */
  int part = InBegin;
  int index = 0;

  if(InEnd >= InBegin)
  {
    part = InBegin;
    for(index = InBegin+1; index <= InEnd; index++)
    {
      if(InArry[InBegin] >= InArry[index])
      {
        /* 交换位置 */
        swap(&InArry[part+1],&InArry[index]);
        part++;
      }
    }

    /* 把第一个数放到part处去 */
    swap(&InArry[InBegin],&InArry[part]);

    return part;
  }

}

/* 快速排序函数
* InArry:输入的数组
* InBegin:数组的开始
*  InEnd:数组的结束
*/
void quickSort(int* InArry,int InBegin,int InEnd)
{
  if(InArry == NULL || InEnd <= InBegin)
  {
    return;
  }

  int part = 0;
  part = getPartion(InArry,InBegin,InEnd);

  /* 递归调用 */
  quickSort(InArry,0,part-1);
  quickSort(InArry,part+1,InEnd);
}

int main()
{
  int a[] = {49,38,65,97,76,13,27};
  int index = 0;

  int len = sizeof(a)/sizeof(int);

  /* 先遍历打印一下数组的元素 */
  for(index = 0; index < len; index++)
  {
    printf("%d ",a[index]);
  }
  printf("\n");

  /* 调用快速排序函数 */
  quickSort(a,0,len-1);

  /* 再遍历打印一下数组的元素 */
  for(index = 0; index < len; index++)
  {
    printf("%d ",a[index]);
  }
  printf("\n");



  return 0;
}

以上就是使用C语言数据结构 快速排序的实例详解,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站 的支持!


# C语言数据结构  # 快速排序实例  # 快速排序的实例  # c语言快速排序算法示例代码分享  # C语言实现选择排序、冒泡排序和快速排序的代码示例  # 用c语言实现冒泡排序  # 选择排序  # 快速排序  # C语言简单实现快速排序  # C语言快速排序函数用法(qsort)  # C语言实现快速排序算法  # C语言的冒泡排序和快速排序算法使用实例  # C语言中快速排序和插入排序优化的实现  # C语言实现快速排序  # C语言实现快速排序算法实例  # 遍历  # 数据结构  # 递归  # 第一个  # 如有  # 希望能  # 刚开始  # 谢谢大家  # 都比  # 先将  # 两部分  # 第一部分  # 第二部分  # 疑问请  # 分隔线  # 这种方法  # void  # Inb  # Ina  # int 


相关文章: Python文件管理规范_工程实践说明【指导】  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  网站制作壁纸教程视频,电脑壁纸网站?  贸易公司网站制作流程,出口贸易网站设计怎么做?  javascript中的try catch异常捕获机制用法分析  ,购物网站怎么盈利呢?  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  如何自定义建站之星模板颜色并下载新样式?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  如何通过万网虚拟主机快速搭建网站?  如何在阿里云虚拟主机上快速搭建个人网站?  网站制作难吗安全吗,做一个网站需要多久时间?  广州美橙建站如何快速搭建多端合一网站?  如何在景安服务器上快速搭建个人网站?  常州企业网站制作公司,全国继续教育网怎么登录?  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  python的本地网站制作,如何创建本地站点?  如何在Tomcat中配置并部署网站项目?  如何通过西部建站助手安装IIS服务器?  XML的“混合内容”是什么 怎么用DTD或XSD定义  Bpmn 2.0的XML文件怎么画流程图  C++用Dijkstra(迪杰斯特拉)算法求最短路径  如何设计高效校园网站?  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  如何通过山东自助建站平台快速注册域名?  盘锦网站制作公司,盘锦大洼有多少5G网站?  网站网页制作专业公司,怎样制作自己的网页?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  岳西云建站教程与模板下载_一站式快速建站系统操作指南  如何在Golang中使用replace替换模块_指定本地或远程路径  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  教学网站制作软件,学习*后期制作的网站有哪些?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  如何基于云服务器快速搭建个人网站?  建站之星如何一键生成手机站?  名字制作网站免费,所有小说网站的名字?  ,交易猫的商品怎么发布到网站上去?  如何做网站制作流程,*游戏网站怎么搭建?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  建站之星代理商如何保障技术支持与售后服务?  ,石家庄四十八中学官网?  如何在Golang中指定模块版本_使用go.mod控制版本号  如何在宝塔面板中创建新站点?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  MySQL查询结果复制到新表的方法(更新、插入)  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  零基础网站服务器架设实战:轻量应用与域名解析配置指南  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  如何选择CMS系统实现快速建站与SEO优化? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。