全网整合营销服务商

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

免费咨询热线: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 


相关文章: 如何打造高效商业网站?建站目的决定转化率  如何通过商城自助建站源码实现零基础高效建站?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  导航网站建站方案与优化指南:一站式高效搭建技巧解析  微课制作网站有哪些,微课网怎么进?  宝塔面板创建网站无法访问?如何快速排查修复?  网站制作软件有哪些,制图软件有哪些?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  建站之星如何实现网站加密操作?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何彻底删除建站之星生成的Banner?  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  如何在Windows虚拟主机上快速搭建网站?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  h5在线制作网站电脑版下载,h5网页制作软件?  建站之星备案是否影响网站上线时间?  微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?  建站之星后台管理如何实现高效配置?  Python lxml的etree和ElementTree有什么区别  如何快速搭建二级域名独立网站?  高端建站三要素:定制模板、企业官网与响应式设计优化  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  h5网站制作工具有哪些,h5页面制作工具有哪些?  如何在云主机上快速搭建网站?  如何快速搭建高效WAP手机网站吸引移动用户?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  实例解析angularjs的filter过滤器  如何选择美橙互联多站合一建站方案?  c# 在高并发场景下,委托和接口调用的性能对比  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  建站之星3.0如何解决常见操作问题?  如何在万网自助建站中设置域名及备案?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  建站之星代理如何优化在线客服效率?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  如何用低价快速搭建高质量网站?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  建站之星导航菜单设置与功能模块配置全攻略  linux top下的 minerd 木马清除方法  建站为何优先选择香港服务器?  重庆网站制作公司哪家好,重庆中考招生办官方网站?  定制建站策划方案_专业建站与网站建设方案一站式指南  如何在Golang中指定模块版本_使用go.mod控制版本号  如何快速配置高效服务器建站软件?  建站主机选购指南与交易推荐:核心配置解析  哈尔滨网站建设策划,哈尔滨电工证查询网站? 

您的项目需求

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