当前位置: 首页 > news >正文

关于外贸公司的网站moodle网站建设

关于外贸公司的网站,moodle网站建设,卷帘门怎么做网站,ppt2016是制作网页的软件一、快速排序的基本原理 快速排序是一种基于分治策略的高效排序算法。它的基本思想是#xff1a; 选择一个基准元素#xff08;pivot#xff09;#xff0c;通过一趟排序将待排序序列分割成两部分#xff0c;其中一部分的所有元素都比基准元素小#xff0c;另一部分的所有… 一、快速排序的基本原理 快速排序是一种基于分治策略的高效排序算法。它的基本思想是 选择一个基准元素pivot通过一趟排序将待排序序列分割成两部分其中一部分的所有元素都比基准元素小另一部分的所有元素都比基准元素大。然后分别对这两部分继续进行快速排序直到整个序列都有序。 二、快速排序的具体实现步骤 1. 选择基准元素 通常可以选择待排序序列中的第一个元素、最后一个元素或者中间元素等作为基准元素。在示例代码中我们常选取待排序数组的最后一个元素作为基准元素例如 隐藏过程 c 复制 int pivot arr[high];2. 划分操作Partition 这是快速排序的关键步骤目的是通过比较和交换元素将数组划分为两部分使得左边部分的元素都小于等于基准元素右边部分的元素都大于等于基准元素。 具体实现过程如下 设置两个指针一个指针 i 初始指向待排序序列的第一个元素的前一个位置即 low - 1另一个指针 j 从待排序序列的第一个元素即 low开始。 展开过程 遍历数组比较每个元素与基准元素的大小关系。当 j 指向的元素小于基准元素时将 i 指针先向前移动一位因为 i 初始位置在第一个元素之前然后交换 i 和 j 所指向的元素。 展开过程 遍历完整个数组除了基准元素本身因为基准元素在最后一个位置前面的循环到 high - 1 就结束了后将基准元素与 i 1 位置的元素进行交换。这样就完成了一次划分操作使得基准元素处于正确的位置左边的元素都小于它右边的元素都大于它。 展开过程 3. 递归排序 完成一次划分操作后得到了基准元素的正确位置假设为 pi此时数组被分成了两部分arr[low] 到 arr[pi - 1] 和 arr[pi 1] 到 arr[high]。然后分别对这两部分递归地调用快速排序函数直到整个数组都有序。 隐藏过程 c 复制 if (low high) {int pi partition(arr, low, high);quickSort(arr, low, pi - 1);quickSort(arr, pi 1, high); }三、快速排序的代码示例 以下是完整的快速排序 C 语言代码示例包含了交换函数 swap、划分函数 partition 和快速排序主函数 quickSort 隐藏过程 c 复制 #include stdio.h// 交换两个整数的函数 void swap(int *a, int *b) {int t *a;*a *b;*b t; }// 划分函数将数组划分为两部分 int partition(int arr[], int low, int high) {int pivot arr[high];int i (low - 1);for (int j low; j high - 1; j) {if (arr[j] pivot) {i;swap(arr[i], arr[j]);}}swap(arr[i 1], arr[high]);return (i 1); }// 快速排序主函数 void quickSort(int arr[], int low, int high) {if (low high) {int pi partition(arr, low, high);quickSort(arr, low, pi - 1);quickSort(arr, high, pi 1);} }int main() {int arr[] {5, 4, 3, 2, 1};int n sizeof(arr) / sizeof(arr[0]);quickSort(arr, 0, n - 1);printf(排序后的数组: );for (int i 0; i n; i) {printf(%d , arr[i]);}return 0; }四、快速排序的时间复杂度和空间复杂度 1. 时间复杂度 平均情况快速排序在平均情况下的时间复杂度为 。这是因为每次划分操作大致能将数组分成两部分需要递归地对两部分进行排序而递归的深度大约为 以 2 为底每次划分操作需要遍历数组中的大约  个元素所以总的时间复杂度为 。最坏情况当选择的基准元素总是数组中的最大或最小元素时每次划分操作只能将数组分成一个元素和其余元素两部分这样就需要进行  次划分操作每次划分操作需要遍历数组中的  个元素此时时间复杂度为 。不过通过合理选择基准元素如随机选择基准元素等方法可以尽量避免这种最坏情况的发生。 2. 空间复杂度 快速排序的空间复杂度取决于递归调用的深度。在平均情况下递归调用的深度为 所以空间复杂度为 。在最坏情况下递归调用的深度为 此时空间复杂度为 。 五、快速排序的特点和应用场景 1. 特点 快速排序是一种原地排序算法它不需要额外的存储空间来存储中间结果除了递归调用栈所占用的空间。它的平均性能非常好通常比冒泡排序、插入排序等简单排序算法快得多。 2. 应用场景 快速排序适用于对大规模数据进行排序的场景尤其是当数据分布比较随机时能够充分发挥其高效的排序性能。在很多编程语言的标准库中快速排序常常被用作默认的排序算法或者是排序算法的重要组成部分。 快速排序通过巧妙的划分操作和递归调用实现了高效的排序功能但在实际应用中也需要注意避免最坏情况的发生以确保其高效性。
http://www.dnsts.com.cn/news/28660.html

相关文章:

  • 贵阳学网站建设网站费用明细
  • 编程代码网站wordpress怎么调用外部主题网页
  • 营销型网站单页面阿里巴巴开店网站怎么做
  • 国外网站风格开发个app多少钱
  • 查询网站流量建信金融科技有限责任公司
  • 做网站 公司噼里啪啦免费观看高清
  • 邢台网站推广报价内容管理系统有哪些
  • 做网站好赚钱吗做led灯网站有哪些呢
  • 网站空间域名每年都得交吗低价网站建设
  • php网站编程网站如何做流量赚钱
  • 如何规划电子商务网站网站建设是什么时间段申请域名
  • 网站怎么做自然优化宁波网站设计首选荣盛网络
  • 绍兴的网站建设公司本地江苏网站建设
  • 设计网站怎么做的wordpress如何把2图片并列
  • 个人网站建设公司地址建网站的支付安全
  • 南京市网站seo整站优化厦门网站建设、
  • 盐城市建设局网站打不开做网站 sql 用哪种
  • 响应式潍坊网站建设如何做运营推广
  • 做网站注册页面天元建设集团有限公司黄岛分公司
  • 河南专业网站建设公司哪家好公司名称怎么取名
  • 爱站网关键词查询怎么免费做网站教程
  • 网页游戏网站7青海媒体网站建设公司
  • 做背景音乐的版权网站临沂网站制作计划
  • 网站建设计划图买极速赛车网站会动手做不
  • 网站开发要学哪些网站更新 缓存
  • 做网站最主要是什么梵克雅宝耳钉
  • 成都专业的网站设计公司广告外链平台
  • 做文案图片上什么网站网站有pc站和手机站
  • 订货网站建设中国著名的个人网站
  • 网站上可以做直播吗网站开发报价表格