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

wordpress修改头图泉州seo托管

wordpress修改头图,泉州seo托管,厦门公司网站建设,全包圆装修公司含义 堆排序就是把数组的内容在心中建立为大根堆,然后每次循环把根顶和没交换过的根末进行调换,再次建立大根堆的过程 建树的几个公式 一个数组有n个元素 最后一个父亲节点是n/2-1; 假如父亲节点在数组的下标为a 那么左孩子节点在数组下标为2*a1,…

含义 

堆排序就是把数组的内容在心中建立为大根堆,然后每次循环把根顶和没交换过的根末进行调换,再次建立大根堆的过程

建树的几个公式

一个数组有n个元素

最后一个父亲节点是n/2-1;

假如父亲节点在数组的下标为a

那么左孩子节点在数组下标为2*a+1,右孩子节点在数组下标为2*a+2

大根堆在心里建树的要点

父亲节点必须大于孩子节点,孩子节点大小位置无影响

【注】数组界限问题,以及传参问题

核心代码

//其实没有树,只不过是我们在心里根据数组层次建树来构建大根堆调整数组的排列顺序
//注意我这里的len是数组的长度,注意一下长度和数组下标间的关系
void AdjustDown(int nums[],int pos,int len)
{int dad = pos;int son = 2*dad+1;//左孩子在数组下标while(son < len){if(son+1<len && nums[son]<nums[son+1]){son++;//挑选出左右孩子最大的,只需把son+1变为右孩子下标}if(nums[son]>nums[dad])//只能父亲大于孩子{swap(nums[son],nums[dad]);//交换数据dad =son;//把当前孩子作为父亲,重新循环son = 2*dad+1;}else{break;}}
}
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
//数组
int nums[]={3,87,2,93,78,56,61,38,12,40};
void init_rand(int nums[],int len)
{srand(time(NULL));for(int i=0;i<len;++i){nums[i]=rand()%100+1;//(1,100)}
}
//交换数据
void swap(int &a,int&b)
{int tmp = a;a=b;b=tmp;
}
void print(int nums[],int len)
{for(int i = 0;i<len ;i++ ){printf("%d ",nums[i]);}printf("\n");
}//其实没有树,只不过是我们在心里根据数组层次建树来构建大根堆调整数组的排列顺序
void AdjustDown(int nums[],int pos,int len)
{int dad = pos;int son = 2*dad+1;//左孩子在数组下标while(son < len){if(son+1<len && nums[son]<nums[son+1]){son++;//挑选出左右孩子最大的,只需把son+1变为右孩子下标}if(nums[son]>nums[dad])//只能父亲大于孩子{swap(nums[son],nums[dad]);//交换数据dad =son;//把当前孩子作为父亲,重新循环son = 2*dad+1;}else{break;}}
}//待排序数组,待排序数组的长度
void heap_sort(int nums[],int len)
{int i;//建立大根堆//从最后一个父亲元素开始for(i=len/2-1;i>=0;--i){//调整没个父亲节点为大根堆//数组,父亲节点所在数组的下标,数组长度AdjustDown(nums,i,len);}//建立大根堆之后,有序的数据是在我们内心中建的树,而不是数组,因此我们还需要把他修改为数组中swap(nums[0],nums[len-1]);//先交换树根和最后一个节点的数据(我这里的len代表长度)// print(nums,len);//接着再次进入建立大根堆,换数据的循环中,直到数组有序for(i=len-1;i>0;i--){AdjustDown(nums,0,i);//每次从父亲节点开始(这里的i代表长度)swap(nums[0],nums[i-1]);//每一次交换树根和(除去数组末尾已经换过的)末尾// print(nums,len);}}int main()
{int len = sizeof(nums)/sizeof(nums[0]);init_rand(nums,len);heap_sort(nums,len);print(nums,len);
}

后序补上解析

http://www.zhongyajixie.com/news/48731.html

相关文章:

  • 专业做网站企业数据分析培训课程
  • 宁夏建设网站推广策略都有哪些
  • 网站建设平台是干什么的苏州优化网站公司
  • 做课内教学网站口碑营销案例2022
  • 叫别人做网站要多久网站模板中心
  • 购销网站建设视频百度云软文推广发稿
  • 宝贝做网站南宁seo排名收费
  • 青州网站搭建网络营销品牌公司
  • 游戏网站开发实验报告自动友链网
  • asp能单独做网站吗沈阳百度seo关键词排名优化软件
  • github制作个人网站360搜索推广
  • 网站建设图片拍摄价格兰州网络seo公司
  • 网站建设的售后服务怎么找到精准客户资源
  • 做网站 站内搜索引擎品牌推广方案思维导图
  • 现在个人做网站还能盈利seo电商运营是什么意思
  • 大学生创意电子产品设计seo诊断服务
  • 网站源码如何使用上海网站建设优化
  • 哪个网站可以做3d今日的头条新闻
  • 鄂尔多斯做网站的公司win7优化工具哪个好用
  • python 做企业网站百度免费网站制作
  • 做的网站被公安局查出漏洞百度热议怎么上首页
  • 网站防护怎么做2023年新闻热点事件摘抄
  • 温州 网站建设链接转二维码
  • wordpress做网址导航专业整站优化
  • 个人建网站成本app制作费用一览表
  • 济南企业网站关键词网络推广企业
  • 网站资讯创作网站自助建站系统
  • 外贸网站建站要多少钱网站免费建站app
  • app平台制作开发seo是什么公司
  • 最好好看的中文字幕东莞百度seo关键词优化