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

中国建设企业协会网站首页郑州网站建设喝彩

中国建设企业协会网站首页,郑州网站建设喝彩,wordpress主题jenney,游戏租号网站怎么建设文章目录 前言一、堆排代码一、计算使用向上调整法建堆的时间复杂度二、计算使用向下调整法插入的时间复杂度总结 前言 在博主的上一篇博客堆排(链接在这里点击即可)的总结中提出啦使用向下调整法建堆比使用向上调整法建堆更好,是因为使用向上调整法建堆的时间复杂…

文章目录

  • 前言
  • 一、堆排代码
  • 一、计算使用==向上调整法==建堆的时间复杂度
  • 二、计算使用==向下调整法==插入的时间复杂度
  • 总结


前言

在博主的上一篇博客堆排(链接在这里点击即可)的总结中提出啦使用向下调整法建堆比使用向上调整法建堆更好,是因为使用向上调整法建堆的时间复杂度为O(n*logn),使用向下调整法建堆的时间复杂度为O(n)。接下来博主就教大家如何计算它们的时间复杂度。


一、堆排代码

void Swap(int* x, int* y)
{int tmp = *x;*x = *y;*y = tmp;
}
//向上调整法
void AdjustUp(HPDataType* arr, int child)
{int parent = (child - 1) / 2;while (child > 0)//不需要等于,child只要走到根节点的位置,根节点没有父节点不需要交换{if (arr[child] < arr[parent])//若孩子结点比父结点小则交换{Swap(&arr[parent], &arr[child]);child = parent;parent = (child - 1) / 2;}else{break;}}
}
//向下调整法
void AdjustDown(HPDataType* arr, int parent, int n)
{int child = parent * 2 + 1;//左孩子while (child < n){//找左右孩子中找最小的if (child + 1 < n && arr[child] > arr[child + 1]){child++;}if (arr[child] < arr[parent]){Swap(&arr[child], &arr[parent]);parent = child;child = parent * 2 + 1;}else{break;}}
}
//堆排
void HeapSort(int* arr, int n)
{//向上调整法建堆for (int i = 0; i < n; i++){AdjustUp(arr, i);}//向下调整算法建堆//for (int i = (n-1-1)/2; i >= 0; i--)//{//	AdjustDown(arr, i , n);//}//循环将堆顶数据跟最后位置的数据进行交换int end = n - 1;while (end > 0){Swap(&arr[0], &arr[end]);AdjustDown(arr, 0, end);end--;}
}

一、计算使用向上调整法建堆的时间复杂度

for (int i = 0; i < n; i++)
{AdjustUp(arr, i);
}
  • 第1层,20个结点,最多需要向上移动0次。
  • 第2层,21个结点,最多需要向下移动1次。
  • 第3层,22个结点,最多需要向上移动2次。
  • 第h-1层,2h-2个结点,最多需要向上移动h-2次。
  • 第h层,2h-1个结点,最多需要向上移动h-1次。
    所以最多移动的次数总和为:
    (1) T(h) = 20(0)+21(1)+22(2)+…+2h-2(h-2)+2h-1(h-1)
    (2) 2T(h) = 21(0)+22(1)+23(2)+…+2h-1(h-2)+2h(h-1)
    (2)-(1) 得
    T(h) = -(21+22+23+…+2h-2+2h-1+2h-1)+2hh
    使用高中阶段学过的等比数列求和公式:S = a1
    (1-qn)/1-q可得
    T(h) = 2(1-2h)+2hh = 2+2h(h-2)
    再根据二叉树的性质:n = 2h-1,h = log2(n+1)可得
    T(n) = 2 + (n+1)(log2(n+1)-2) = (n+1)log2(n+1)-2
    n
    所以向上调整法建堆的时间复杂度为O(logn*n)

二、计算使用向下调整法插入的时间复杂度

for (int i = (n-1-1)/2; i >= 0; i--)
{AdjustDown(arr, i , n);
}
  • 第1层,20个结点,最多需要向下移动h-1次。
  • 第2层,21个结点,最多需要向下移动h-2次。
  • 第3层,22个结点,最多需要向下移动h-3次。
  • 第h-1层,2h-2个结点,最多需要向下移动1次。
  • 第h层,2h-1个结点,最多需要向下移动0次。

所以最多移动的次数总和为:
(1) T(h) = 20(h-1)+21(h-2)+22(h-3)+…+2h-2(1)
(2) 2T(h) = 21(h-1)+22(h-2)+23(h-3)+…+2h-1(1)
(2)-(1) 得
T(h) = 21+22+23+…+2h-2+2h-1-20(h-1)
T(h) =20+ 21+22+23+…+2h-2+2h-1-h
使用高中阶段学过的等比数列求和公式:S = a1
(1-qn)/1-q可得
T(h) = 2h-1-h
再根据满二叉树的性质:n = 2h-1,h = log2(n+1)可得
T(n) = n-log2(n+1)
*
所以向下调整法建堆的时间复杂度为O(n)


总结

通过这篇博客相信柚柚们已经清楚向下调整法建堆和向上调整法建堆的时间复杂度怎么计算啦,后期博主还会更新有关数据结构的博客,感兴趣的柚柚们可以关注博主喔~

http://www.yayakq.cn/news/117244/

相关文章:

  • 怎么做asp网站长沙seo服务哪个公司好
  • 网站2级目录怎么做的网站后台图片传不上去怎么办
  • 宁夏住房和城乡建设厅网站用什么做asp网站
  • 微网站 具有哪方面的优势网站打赏怎么做的
  • 建设一个电子文学网站资金多少室内设计师培训网
  • 绥化网站建设公司wordpress 远程图片本地化
  • 销售型企业网站有哪些购物网站开发用什么软件
  • 面试网站建设问题百度容易收录哪些网站
  • 网站开发的进度控制计划表seo营销推广费用
  • 长春网站建设sok免费注册网站免登录
  • html如何做网站网站安全如何做
  • 阿里巴巴做国际网站多少钱桂林北站防疫电话
  • 查看网站是否被k自己做网站花多少钱
  • 昆明公司网站建设wordpress熊账号
  • 周口市建设职工培训中心网站怎么开通自媒体账号赚钱
  • 青岛做网站哪个公司好自己做网站需要收费吗
  • 成都建设网站首页网站主体负责人和网站负责人
  • 西部数码网站管理助手 伪静态茶叶网络推广方案
  • 水土保持与生态建设网站国外seo
  • 网络 网站莒南县建设局网站
  • 襄阳高端网站建设游戏网站建设教程
  • 做网站选择什么相机网站内如何@
  • 做门窗接活的网站合肥网站公司哪家好
  • 华东网站建设福州市住房和城乡建设局官网
  • 唯美网站模板建筑公司企业愿景文案平台
  • 哈尔滨如何做网站推广优化app网站模板下载
  • 十堰商城网站建设精准营销公司
  • 陕西建设网官方网站做图书网站赚钱吗
  • 举例行业门户网站seo公司怎么样
  • 哪家做网站做得好网站右下角图片代码