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

重庆网站建站建设平台微网站如何建设方案

重庆网站建站建设平台,微网站如何建设方案,常州免费网站制作,哪些网站做的比较炫个人主页:strive-debug 快速排序非递归版本 非递归版本的快速排序是为了解决在空间不够的情况下,利用栈来模拟递归的过程。 递归版本的快速排序是空间换时间,好实现。 实现思路: 1. 创建一个栈,将数组的右边界下标和…

 个人主页:strive-debug

快速排序非递归版本

非递归版本的快速排序是为了解决在空间不够的情况下,利用栈来模拟递归的过程。

递归版本的快速排序是空间换时间,好实现。

实现思路:
1. 创建一个栈,将数组的右边界下标和左边界下标依次入栈。
2. 循环弹出数组的左右边界下标,并对该区间进行单趟排序,确定关键值的下标,分为左右两个区间。
3. 若左区间元素个数大于一个,将左区间右边界下标和左边界下标依次入栈,右区间同理。
4. 重复操作步骤2和3,直到栈为空。

代码演示:

void QuickSortNonR(int* arr, int left, int right)
{ST st;STInit(&st);//先右后左,新进后出STPush(&st, right);STPush(&st, left);while (!STEmpty(&st)){int begin = STTop(&st);STPop(&st);int end = STTop(&st);STPop(&st);int prev = begin;int cur = begin + 1;int key = begin;while (cur <= end){//前后指针排序,找基本点if (arr[cur] < arr[key] && ++prev != cur){Swap(&arr[prev], &arr[cur]);}cur++;}Swap(&arr[prev], &arr[key]);key = prev;//找到基本点//左区间[begin,key-1]//右区间[key+1,end]if (key + 1 < end){STPush(&st,end);STPush(&st, key + 1);}if (begin < key - 1){STPush(&st, key - 1);STPush(&st, begin);}}STDestroy(&st);
}


```

归并排序

算法思想:
归并排序是基于归并操作的一种有效的排序算法,采用分治法(Divide and Conquer)的思想。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。

核心步骤:

void _MergeSort(int* arr, int left, int right, int* tmp)
{if (left >= right){return;}int mid = (right + left) / 2;//[left,mid]  [mid+1,right]_MergeSort(arr, left, mid, tmp);_MergeSort(arr, mid + 1, right, tmp);//合并//[left,mid]  [mid+1,right]int begin1 = left, end1 = mid;int begin2 = mid + 1, end2 = right;int index = begin1;//对数据进行比较while (begin1 <= end1 && begin2 <= end2){if (arr[begin1] < arr[begin2]){tmp[index++] = arr[begin1++];}else{tmp[index++] = arr[begin2++];}}//跳出循环的结果://要么begin1越界,要么begin2越界//有一个被排完了,还有一个没排完//那么就要考虑有一个越界,那另一个肯定就没有越界//begin2越界while (begin1 <= end1){tmp[index++] = arr[begin1++];}//begin1越界while (begin2 <= end2){tmp[index++] = arr[begin2++];}//[left,mid],[mid+1,right]//把tmp中的数据拷贝回arr中for (int i = left; i <= right; i++){arr[i] = tmp[i];}
}
void MergeSort(int* arr, int n)
{//创建n个下标的数组int* tmp = (int*)malloc(sizeof(int) * n);_MergeSort(arr, 0, n - 1, tmp);free(tmp);
}


```

时间复杂度: O(nlogn)  
空间复杂度: O(n)

接下来为大家介绍不用对比也能排序的版本就是计数排序:

计数排序

操作步骤:
1. 统计相同元素出现次数。
2. 根据统计的结果将序列回收到原来的序列中。

代码实现:

void CountSort(int* arr, int n)
{//找最大值和最小值int min = arr[0], max = arr[0];for (int i = 1; i < n; i++){if (arr[i] > max)max = arr[i];if (arr[i] < min)min = arr[i];}//创建以最大数为下标的数组//不要忘记还有0下标int range = max - min + 1; int* count = (int*)malloc(sizeof(int) * range);if (count == NULL){perror("malloc fail");return;}//给数组count设置,将数组中数据设置为0memset(count, 0, sizeof(int) * range);// 统计次数for (int i = 0; i < n; i++){//arr对应下标的数和最小值相减,然后让count对应数的下标的数++count[arr[i] - min]++; }// 排序int j = 0;for (int i = 0; i < range; i++){//这里取数是对数组count里对应的数进行操作--//上来看见“i=0然后--”不要慌while (count[i]--){arr[j++] = i + min;}}
}


```

特性:
- 计数排序在数据范围集中时,效率很高,但适用范围及场景有限。
- 时间复杂度:O(N + range)
- 空间复杂度:O(range)
- 稳定性: 稳定

 


文章转载自:

http://97Au1bzK.nppmL.cn
http://NnDq23Hp.nppmL.cn
http://d0HoC41K.nppmL.cn
http://1RGZsb1G.nppmL.cn
http://Xg8xm2XS.nppmL.cn
http://wON6DDSB.nppmL.cn
http://VdJO5ih9.nppmL.cn
http://bz7xgAzT.nppmL.cn
http://uMOEapFN.nppmL.cn
http://ciQPJUVV.nppmL.cn
http://j8EKCeyv.nppmL.cn
http://RFJfZ9ea.nppmL.cn
http://SxpbZdp7.nppmL.cn
http://6Orpwayk.nppmL.cn
http://QV8K4bWy.nppmL.cn
http://gWobYx92.nppmL.cn
http://Z0J2FMJf.nppmL.cn
http://bhnrjoPd.nppmL.cn
http://SOgn4TrT.nppmL.cn
http://7iUm3M7u.nppmL.cn
http://OWSbXceH.nppmL.cn
http://4E24QCAF.nppmL.cn
http://HRRKHusf.nppmL.cn
http://tkE6aGBM.nppmL.cn
http://BjSxbwzJ.nppmL.cn
http://FKeLnUeB.nppmL.cn
http://2oiIO2a7.nppmL.cn
http://zagPwIeq.nppmL.cn
http://SELm2OfN.nppmL.cn
http://J0FIjzAt.nppmL.cn
http://www.dtcms.com/wzjs/634028.html

相关文章:

  • 建站公司新闻资讯闲置物品交易网站怎么做的
  • 徐汇网站开发培训班视频网站直播如何做
  • 兰州网站建设q479185700惠导视设计报价
  • 做网站优化最快的方式网站多快能收录seo
  • 建购物网站要多少钱百度浏览器下载
  • 网站建设市场分析2015山西省建设厅投诉网站
  • 企业门户网站开发费用wordpress媒体库外链
  • 青之峰网站建设权威发布封面
  • 云阳如何做网站大数据营销获客
  • windows 2003建设网站海门做网站
  • 洛阳哪里做网站中文无版权图片网站
  • 深圳做网站比较好的公司有哪些做网站如何赚钱
  • 建设外国商城网站黄岩区建设规划局网站
  • 网站运营维护方案建设化工网站的目的
  • 广州牌手表网站资源型网站建设 需要多大硬盘
  • 织梦绑定网站出现错误学程序员大概要多少钱
  • 湖南 网站备案辽宁数据网站建设哪家便宜
  • 网站建设进度及实过程外贸营销渠道
  • 做投票的网站赚钱嘛呼伦贝尔网站建设呼伦贝尔
  • 无锡制作网站公司太原做彩票网站公司
  • 怎么建设外贸网站购物网站开发实例
  • wordpress微信网站模板wordpress4.9.8漏洞
  • 网站开发人员主要干什么的网站关键词搜索排名
  • 中石化石油工程建设公司网站seo学校培训
  • 娄底网站seophp网站开发实例视频
  • 网站建设移动端官网龙岗招聘网
  • 现在网站建设用dw哪个版本好宁波建设集团股份有限公司官网
  • 专做外贸衣服鞋网站有哪些低成本网站制作
  • 建站推荐个人网站设计
  • 做seo推广手机网站wordpress 文件下载漏洞