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

做一万个网站网络营销策划的目的

做一万个网站,网络营销策划的目的,网站的功能性,做网站的一个月能赚多少钱目录 1.引入 2.非递归实现快排的思想 3.非递归实现快排图解 4.完整代码 1.引入 递归不可避免的话题就是防止栈溢出 所以程序员需要具备递归改非递归的能力 ,一般来说,抓住递归中变化的量是关键 void QuickSort(int* a, int left, int right){if (left…

目录

1.引入

 2.非递归实现快排的思想

3.非递归实现快排图解

4.完整代码


 

1.引入

递归不可避免的话题就是防止栈溢出

所以程序员需要具备递归改非递归的能力 ,一般来说,抓住递归中变化的量是关键

void QuickSort(int* a, int left, int right){if (left >= right)return;if (right - left + 1 < 10){InsertSort(a + left, right - left + 1);}else{int keyi = PartSort1(a, left, right);//[left, keyi - 1] keyi [keyi + 1, right]QuickSort(a, left, keyi - 1);QuickSort(a, keyi + 1, right);}
}

递归调用实现快速排序类似于二叉树的前序遍历(根、左子树、右子树)

仔细观察可知,栈帧中变化的是具体的区间边界

 2.非递归实现快排的思想

配合使用这种结构以模拟递归实现快排时的前序遍历

先将起始区间边界存入栈中,然后取出边界,进行快排的单趟排序得到分界位置的下标,以此为界将数组分割为左右两部分,然后先将右部分的区间边界存入栈中,再将左部分的区间边界存入栈中(区间大小大于1才将边界存入栈中),再从栈中取出区间边界进行单趟排序,再分割数组并存入区间边界....直到栈为空为止

简单来说就是存边界、取边界排序、分数组存边界、取边界排序、分数组存边界.......

3.非递归实现快排图解

依据思想, 存边界、取边界排序、分数组存边界、取边界排序、分数组存边界.......

直到栈为空时停止,此时数组有序

4.完整代码

typedef int STDataType;
typedef struct Stack
{STDataType* a;int top;int capacity;
}ST;
//初始化
void STInit(ST* ps);
//销毁
void STDestroy(ST* ps);
//压栈
void STPush(ST* ps, STDataType val);
//出栈
void STPop(ST* ps);
//大小
int STSize(ST* ps);
//判空
bool STEmpty(ST* ps);
//访问栈顶
STDataType STTop(ST* ps);void QuickSortNonR(int* a, int left, int right){//区间不存在就返回if (left >= right)return;//小规模数组直接优化if (right - left + 1 < 10){InsertSort(a + left, right - left + 1);return;}//C语言实现的栈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);//小规模数组直接优化if (end - begin + 1 < 10){InsertSort(a + begin, end - begin + 1);continue;}int keyi = PartSort3(a, begin, end);//[begin, keyi - 1] keyi [keyi + 1, end]if (begin < keyi - 1){STPush(&st, keyi - 1);STPush(&st, begin);}if (keyi + 1 < end){STPush(&st, end);STPush(&st, keyi + 1);}}STDestroy(&st);
}

注意边界的存入方式 、小规模数组可以进行优化

http://www.lryc.cn/news/616904.html

相关文章:

  • 杭州做网站需要多少钱代写软文费用全网天下实惠
  • 科技布沙发优缺点黑帽seo排名技术
  • 3一6年级科技小制作手工baiduseoguide
  • 免费设计网站平台网络推广营销网
  • 自己做的旅游网站简介外贸网站优化公司
  • 山西手机版建站系统信息aso优化是什么意思
  • 秦皇岛黄金海岸好玩吗深圳seo优化排名
  • 汕头网站建设科技有限公司赛雷猴是什么意思
  • 广州学做网站浏阳廖主任打人
  • 合肥专业做网站公司蚌埠网络推广
  • 做汽车配件生意的网站软件培训机构排行榜
  • htm网站开发 实训市场营销推广
  • 济南网站建设培训班网站推广怎么做有效果
  • 网站建设公司哪家好 地址磐石网络朝阳区seo搜索引擎优化介绍
  • 网上做兼职正规网站怎么找推广渠道
  • 怎么做电影网站app网页设计与制作书籍
  • 杭州低价做网站百度一下你就知道原版
  • github 做自己的网站友链对网站seo有帮助吗
  • WordPress5分钟建站近期时事新闻
  • 游戏网站的监管由谁来做竞价恶意点击立案标准
  • 如何搭建自己的网站服务器地址太原建站seo
  • 厦门唯一官方网站网站优化靠谱seo
  • 德庆网站建设公司网站自然优化
  • 免费做网站有哪些家厦门百度代理
  • 自己怎样做网站免费b站软件推广网站2023
  • 深圳营销型网站建设公司网络服务百度关键词权重查询
  • 做网站如何接单网站怎么申请怎么注册
  • 网站上做商城可用同一域名百度下载应用
  • 新网站做百度百科seo查询外链
  • asp网站开发工具神器全国免费发布信息平台