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

重庆网上制作网站哪个网站专门做游戏脚本

重庆网上制作网站,哪个网站专门做游戏脚本,太原网站建设的公司排名,最干净在线代理​#x1f47b;内容专栏#xff1a; 《数据结构与算法篇》 #x1f428;本文概括#xff1a; 利用数据结构栈(Stack)来模拟递归#xff0c;实现快排的非递归版本#xff1b;递归版本测试OJ题时#xff0c;有大量重复元素样例不能通过#xff0c;导致性能下降#xff0… ​内容专栏 《数据结构与算法篇》 本文概括 利用数据结构栈(Stack)来模拟递归实现快排的非递归版本递归版本测试OJ题时有大量重复元素样例不能通过导致性能下降优化快速排序通过将数组划分为三个区域可以更有效地处理重复元素。 本文作者 阿四啊 发布时间2023.8.28 快速排序(非递归) 1.为什么要学习非递归版本? 前面我们使用了三个版本实现快速排序但都是属于递归类型算法函数调用会建立函数栈帧递归深度取决于函数调用的次数。栈空间内存有限在处理大规模数据集时递归深度的增加可能导致栈溢出的情况所以在我们学会了递归版本之后需要继续强化学习非递归版本利用之前学习的数据结构栈(Stack)来模拟实现。 2.基本思想 我们知道我们在写递归版本的时候快速排序主要处理的是数组的不同区间将问题分解为较小的子问题并在每个子问题上递归地应用相同的排序算法来完成排序。 那么我们如何使用栈(Stack)来模拟实现呢? 核心思想是使用一个栈来存储待排序的子数组的起始和结束下标。在每次循环中从栈中弹出一个子数组并执行分区操作根据基准值(key)划分区间这一步骤即递归版本写的Partition函数选然后根据分区结果将未处理的左右子数组的下标压入栈中直到栈为空为止。 3.算法分析 ① ② ③继续重复以上步骤直到栈中的数据为空。 4.代码实现 因为涉及到使用栈而本篇数据结构基于C语言讲解所以讲自己实现的栈的文件源代码也顺便放在这。 void Swap(int* a, int* b) {int tmp *a;*a *b;*b tmp; } //hoare版本 int Partition1(int* a, int left, int right) {int keyi left;while (left right){//注意 要加上left right 否则会出现越界//若不判断等于基准值也会出现死循环的情况//右边找小while (left right a[right] a[keyi]){right--;}//左边找大while (left right a[left] a[keyi]){left;}Swap(a[left], a[right]);}Swap(a[left], a[keyi]);return left; }void QuicksortNonR(int* a, int begin, int end) {Stack st;StackInit(st);//注意栈的顺序是后进先出需要倒着放进去正着拿出来//将排序数组的起始和末端下标入栈StackPush(st, end);StackPush(st, begin);//栈不为空一直循环while (!StackEmpty(st)){//弹出子区间(左右两个下标)int left StackTop(st);StackPop(st);int right StackTop(st);StackPop(st);//执行分区操作int keyi Partition1(a, left, right);//[left,keyi - 1] keyi [keyi 1, right]//注意只剩一个数或区间不存在则停止入栈if (keyi 1 right){StackPush(st,right);StackPush(st,keyi 1);}if (left keyi - 1){StackPush(st, keyi - 1);StackPush(st, left);}}} void PrintArray(int* a, int n) {for (int i 0; i n; i){printf(%d , a[i]);} } int main() {int a[] { 9,6,7,1,4,5,5,2,10,1,6,3,7 };QuicksortNonR(a, 0, sizeof a / sizeof(int) - 1);PrintArray(a, sizeof a / sizeof(int)); }栈 相关函数声明 #pragma once #include stdio.h #include stdbool.h #include assert.h #include stdlib.h typedef int DataType; typedef struct Stack {DataType* a;int top;int capacity;}Stack;//栈的初始化 void StackInit(Stack* pst); //入栈 void StackPush(Stack* pst,DataType x); //出栈 void StackPop(Stack* pst); //栈的销毁 bool StackEmpty(Stack* pst); //获取栈顶元素 DataType StackTop(Stack* pst); //获取栈元素个数 int StackSize(Stack* pst); //栈的销毁 void StackDestroy(Stack* pst);相关函数实现 #define _CRT_SECURE_NO_WARNINGS #include stack.h //栈的初始化 void StackInit(Stack* pst) {assert(pst);pst-a NULL;//pst-top -1;//栈顶元素的位置pst-top 0;//栈顶元素的下一个位置pst-capacity 0; } //入栈 void StackPush(Stack* pst,DataType x) {if (pst-top pst-capacity){int newCapacity pst-capacity 0 ? 4 : (pst-capacity) * 2;DataType* tmp (DataType*)realloc(pst-a, sizeof(DataType) * newCapacity);if (tmp NULL){perror(realloc fail\n);return;}else{pst-a tmp;pst-capacity newCapacity;}}pst-a[pst-top] x; } //出栈 void StackPop(Stack* pst) {assert(pst);pst-top--; } //判断栈是否为空 bool StackEmpty(Stack* pst) {assert(pst);return pst-top 0; } //获取栈顶元素 DataType StackTop(Stack* pst) {return pst-a[pst-top - 1]; } //获取栈元素个数 int StackSize(Stack* pst) {return pst-top; } //栈的销毁 void StackDestroy(Stack* pst) {assert(pst);free(pst-a);pst-a NULL;pst-top pst-capacity 0; }总结 时间复杂度O(N*logN) 空间复杂度O(logN) ⚠️注意尽管使用栈实现了递归过程但栈的使用本质上是在模拟递归调用栈。这种方法可以避免递归深度过大导致栈溢出的问题并且在一些情况下比递归版本更有效。 递归版本优化(三路划分) 1.缺陷问题 下面给出一道力扣OJ题传送链接:912.排序数组 题目要求就是给定一些数据将乱序的数组排列为升序。我们用希尔排序、归并排序、堆排序……一般效率较高的都可以跑过但是唯独快排用递归、非递归都不能跑过就很离谱因为快排有名也就是这题故意针对快排下面利用写出的递归版本的快排去跑这个OJ。 /*** Note: The returned array must be malloced, assume caller calls free().*/void Swap(int* p1, int* p2) {int tmp *p1;*p1 *p2;*p2 tmp; } //三数取中 int GetMidIndax(int* a,int left, int right) {int mid left (rand() % (right - left));if (a[mid] a[left]){if (a[right] a[mid]) return mid;else if (a[right] a[left]) return right;else return left;}else //a[mid] a[left]{if (a[right] a[mid]) return mid;else if (a[right] a[left]) return right;else return left;}}//hoare版本 int Partition1(int* a, int left, int right) {int midi GetMidIndax(a, left, right);Swap(a[left],a[midi]);int keyi left;while (left right){//右边找小while (left right a[right] a[keyi]){right--;}//左边找大while (left right a[left] a[keyi]){left;}Swap(a[left], a[right]);}Swap(a[left], a[keyi]);return left; }//快排(递归版本) void QuickSort(int* a, int begin, int end) {if (begin end) return;int keyi Partition1(a, begin, end);//前序遍历//递归基准值左边的区间QuickSort(a, begin, keyi - 1);//递归基准值右边的区间QuickSort(a, keyi 1, end); }int* sortArray(int* nums, int numsSize, int* returnSize){QuickSort(nums, 0, numsSize - 1);*returnSize numsSize;return nums; }我们发现这题一共21个测试用例只通过了17个显示超出时间限制并且nums里出现了很多2因为有大量重复元素样例不能通过这样的基准值key一直是处于数组第一个位置导致性能下降出现了最坏的情况时间复杂度为O(N2) 2.解决方案 [----------------------------------------------------------------------------------------------------------------------------------------] 基本思想三路划分通过将数组划分为三个部分来解决这个问题小于、等于和大于基准值的元素。 用随机值三数取中法选择一个基准值key 。定义三个指针变量left、cur、rightleft的初始值为区间的起始位置cur指针的初始值为left 1right指针的初始值为区间的末尾位置。遍历数组通过与基准值的比较将元素分成三部分 如果当前元素小于key 将它与left指针所指的位置交换然后将left指针和cur指针都向右移动。如果当前元素等于key 将cur指针向右移动。如果当前元素大于key 将它与right指针所指的位置交换然后将right指针向左移动。 left指针和right指针之间的区域(包含left和right)即为与key相等的所有元素然后前序遍历对left指针左边区域进行递归right指针右边区域进行递归。最终数组会被划分为三个区域小于key区域 、等于key区域 和大于key区域。 3.代码参考 /*** Note: The returned array must be malloced, assume caller calls free().*/ void Swap(int* p1, int* p2) {int tmp *p1;*p1 *p2;*p2 tmp; } int GetMidIndax(int* a,int left, int right) {int mid left (rand() % (right - left));if (a[mid] a[left]){if (a[right] a[mid]) return mid;else if (a[right] a[left]) return right;else return left;}else //a[mid] a[left]{if (a[right] a[mid]) return mid;else if (a[right] a[left]) return right;else return left;}} //三路分割 左 l r 右 void QuickSort(int* a, int begin, int end) {if (begin end) return;int left begin;int right end;int cur left 1;int mid GetMidIndax(a, begin, end);Swap(a[mid],a[left]);int key a[left];while (cur right){if (a[cur] key){Swap(a[cur], a[left]);left;cur;}else if (a[cur] key){Swap(a[cur], a[right]);right--;}else //a[cur] key{cur;}}// [begin left- 1],[left,right],[right 1,end]QuickSort(a, begin, left - 1);QuickSort(a, right 1, end); }int* sortArray(int* nums, int numsSize, int* returnSize){srand(time(NULL));QuickSort(nums, 0, numsSize - 1);*returnSize numsSize;return nums; }
http://www.w-s-a.com/news/832355/

相关文章:

  • 易签到网站开发设计做网站运营有前途吗
  • 南通网站建设心得2023必考十大时政热点
  • 苍溪建设局网站公建设计网站
  • 九歌人工智能诗歌写作网站电子商务网站建设项目书
  • 做外贸的经常浏览的三个网站律师做哪个网站好
  • 中国公路建设招标网站长沙大型网站建设公司
  • 沈阳企业网站模板建站注册电子邮箱免费注册
  • 如何做简洁网站设计企业网站排名优化方案
  • 东莞网站建设服务商做触屏网站
  • 外国网站代理音乐网站建设
  • 珠江网站建设广安广告公司
  • 高端创意网站建设网页制作咨询公司
  • 网站建设及发布的流程图wordpress文章摘要显示
  • 淮北网站网站建设省好多会员app
  • 如何查看网站的更新频率网站图片要求
  • 网站设计公司收费标准wordpress修改文章链接
  • 镇江网站建设公司网站关键词密度怎么计算的
  • c 网站开发公司的网站的设计
  • 网站建设多长时间能学会做网站猫要做端口映射吗
  • 新手做网站视频网页设计期末作品要求
  • 做网站用户充值提现郑州高端模板建站
  • 运城做网站方式方法网站改版完成
  • 上海建设网站制作东西湖建设局网站
  • 建设购物网站课程设计建设部领导干部官方网站
  • 沈阳企业制作网站北京两学一做网站
  • 郑州做营销型网站手机网站建设多少钱一个
  • 小说类网站程序外贸商城 wordpress
  • 喀什百度做网站多少钱wordpress 用户介绍
  • 专门做任务的网站手机端网站重构
  • 深圳专业设计网站公司国际网站建设经验