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

WordPress建站要花钱js做示爱网站例子

WordPress建站要花钱,js做示爱网站例子,广东深圳手机号码,如何做网站不容易被攻击目录 快速排序划分快排 随机划分的快速排序 快速排序 快速排序是排序算法中平均时间复杂度为O(nlogn)的一种算法。 划分 快排的实现需要解决划分的问题#xff1a;对于一个序列A[1]、A[2]、……、A[n]#xff0c;从中选取一个枢轴#xff08;或主元#xff09;#xff… 目录 快速排序划分快排 随机划分的快速排序 快速排序 快速排序是排序算法中平均时间复杂度为O(nlogn)的一种算法。 划分 快排的实现需要解决划分的问题对于一个序列A[1]、A[2]、……、A[n]从中选取一个枢轴或主元如取A[1]为枢轴调整序列中元素的位置使得枢轴左侧所有元素都不超过枢轴右侧所有元素都大于枢轴。 双指针思想 先将A[1]存放至某个临时变量temp并令两个下标left、right分别指向序列首尾如令left 1、right n。只要right指向的元素A[right]大于temp就将right不断左移当某个时候A[right] ≤ temp时将元素A[right]挪到left指向的元素A[left]处。只要left指向的元素A[left]不超过temp就将left断右移当某个时候A[left] temp时将元素A[left]挪到right指向的元素A[right]处。重复②③直达left与right相遇把temp也即原A[1]放到相遇的地方。 以A[left]为枢轴写出划分区间代码 // 对区间[left,right]进行划分 int partition(int left, int right, int A[]) {int temp A[left]; // 将A[left]存放至临时变量tempwhile (left right) { // left right,即枢轴位置while (left right temp A[right]) right--; // 反复左移rightA[left] A[right]; // 将A[right]挪到A[left]while (left right A[left] temp) left; // 反复右移leftA[right] A[left]; // 将A[left]挪到A[right]}A[left] temp; // 把temp放到left与right相遇的地方return left; // 返回相遇的下标 }快排 调整序列中的元素使当前序列最左端的元素在调整后满足左侧所有元素均不超过该元素右侧所有元素均大于该元素。对该元素的左侧和右侧分别递归进行①的调整直到当前调整区间的长度不超过1。 // 快速排序,left与right初值为序列首尾下标(如1与n) void quick_sort(int left, int right, int A[]) {if (left right) { // left right时,区间只有一个元素int pivot partition(left, right, A); // 将[left,right]按A[left]一分为二quick_sort(left, pivot - 1, A); // 对左子区间递归进行快速排序quick_sort(pivot 1, right, A); // 对右子区间递归进行快速排序} }随机划分的快速排序 当序列中元素接近有序时选取A[left]作为主元快速排序可能会达到最坏时间复杂度O(n2)。采用随机选择主元的方法则对任意输入数据的期望时间复杂度都能达到O(nlogn)。C语言中产生随机数据 需要添加stdlib.h头问题与time.h头文件。生成随机数的种子写上srand((unsigned) time(NULL));记住即可。在需要使用随机数的地方使用rand()函数。生成[left, right]范围内的随机数 1. rand()函数生成[0RAND_MAX]范围内的随机数。 2. 用这个随机数除以RAND_MAX得到一个[01]范围内的浮点数。 3. 用这个浮点数乘以(right - left)加上left。 4. 再用round()函数需要math.h头文件四舍五入后得到[leftright]范围内的随机数。 5. 这个浮点数相当于[leftright]范围内的比例位置。 6. 例rand()生成的随机数经过处理得到浮点数为0.5left 2right 5right - left 33 * 0.5 1.51.5 2 3.5round(3.5) 4得到[25]范围内的随机数4。 #include stdlib.h #include time.h #include math.h// 交换两个数的值 void swap(int *a, int *b) {int temp *a;*a *b;*b temp; }// 选取随机主元,对区间[left,right]进行划分 int randPartition(int left, int right, int A[]) {// 生成随机数种子srand((unsigned) time(NULL));// 生成[left,right]范围内的随机数pint p (int) round((1.0) * rand() / RAND_MAX * (right - left) left);// 交换A[left]和A[p]swap(A[left], A[p]);// 以下为原先partition函数的划分过程,不需要改变任何东西int temp A[left]; // 将A[left]存放至临时变量tempwhile (left right) { // left right,即枢轴位置while (left right temp A[right]) right--; // 反复左移rightA[left] A[right]; // 将A[right]挪到A[left]while (left right A[left] temp) left; // 反复右移leftA[right] A[left]; // 将A[left]挪到A[right]}A[left] temp; // 把temp放到left与right相遇的地方return left; // 返回相遇的下标 }// 快速排序,left与right初值为序列首尾下标(如1与n) void quick_sort(int left, int right, int A[]) {if (left right) { // left right时,区间只有一个元素int pivot randPartition(left, right, A); // 将[left,right]按A[left]一分为二quick_sort(left, pivot - 1, A); // 对左子区间递归进行快速排序quick_sort(pivot 1, right, A); // 对右子区间递归进行快速排序} }
http://www.pierceye.com/news/504818/

相关文章:

  • 重庆网站seo搜索引擎优化网站qq登录 开发
  • 备案号放网站下面居中物流网站制作目的
  • 房产网站排名做情侣网站
  • 营销型网站建设推荐国内团购网站做的最好的是
  • 前端网站建设苏州高新区建设局网站管网
  • 中小企业网站建设中服务器的解决方案是网站建设推广总结
  • 东莞网站建设新闻资讯做赌场网站犯法么
  • wordpress怎么添加单页模版seo价格是多少
  • 网站域名有了_网站如何建设优书网首页
  • 宠物网站建设策划报告Wordpress is文章展示
  • 电子建设网站的目的阿里巴巴网站是用什么技术做的
  • 图形设计网站wordpress微信群多个二维码
  • 网站建设维护是干什么网站用户需求报告
  • 咸宁网站建设公司水网站模板
  • 移动网站开发教材seo网站排名优化价格
  • 重生做网站小说畅想网络网站建设推广
  • 找个做网站的 优帮云wordpress 判断自定义栏目
  • wordpress文章目录分页wordpress加速优化服务
  • 二级目录网站怎么做小程序开发成都公司
  • 网站标题名字和备案名字网站开发 质量管理
  • 网站与系统开发吉安网站建设收费
  • 湖北襄阳网站建设wordpress电商ar
  • 微做网站环保行业网站建设
  • 昭通做网站公司北京手机网站制作多少钱
  • 昆明企业建网站多少钱如何弄微信小程序
  • wordpress清理网站缓存做的比较简约的网站
  • 青岛高端网站制作中铁建设集团门户密码
  • 公司专业做网站做网站域名起什么作用
  • 推广型网站建设机构如何创建wordpress
  • 做网站交互demo工具在线设计自己的签名免费