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

汕头建站模板系统百度客服24小时电话人工服务

汕头建站模板系统,百度客服24小时电话人工服务,大连推广网站搭建哪家好,网站直播怎么做1.堆的概念 如果有一个关键码的集合 K { k1 &#xff0c;k2 &#xff0c;k3 &#xff0c;…&#xff0c;kn }&#xff0c;把它的所有元素按完全二叉树的顺序存储方式存储在一个一维数组中&#xff0c;并且 k(i) < k(i*21) 和 k(i) < k(i*22)&#xff0c; i 0 &#xff…

1.堆的概念

如果有一个关键码的集合 K = { k1 ,k2 ,k3 ,…,kn },把它的所有元素按完全二叉树的顺序存储方式存储在一个一维数组中,并且 k(i) < k(i*2+1) 和 k(i) < k(i*2+2), i = 0 1 , 2…,则称为小堆 ( 或大堆 ) 。将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆。

1.1堆的性质 

堆中某个节点的值总是不大于或不小于其父节点的值;
堆总是一棵完全二叉树。

1.2堆的存储结构

 

2.堆的实现

  堆的构建
 堆的销毁
 堆的插入
  堆的删除
  取堆顶的数据
  堆的数据个数
  堆的判空

2.1堆的构造与销毁

 

void HeapInit(HP* php)
{assert(php);php->a = NULL;php->size = 0;php->capacity = 0;
}void HeapDestroy(HP* php)
{assert(php);free(php->a);php->a = NULL;php->size = 0;php->capacity = 0;
}

 2.2堆的向上与向下调整

void swap(DataType*str1, DataType*str2)
{DataType temp = *str1;*str1 = *str2;*str2 = temp;
}
//向上调整(前提是上面是一个堆)
void AdjustUp(DataType* a, int child)
{//利用孩子找父亲,并且比较int parent = (child - 1) / 2;while (child > 0){// "<" 和 ">"取决与建立大小堆if (a[child] < a[parent]){swap(&a[child], &a[parent]);child = parent;parent = (child - 1) / 2;}else{break;}}
}
//向下调整(前提是下面左右子树是一个堆)
void AdjustDown(int* a, int n, int parent)//n是数量
{//利用父亲找儿子并比较大小int child = parent * 2 + 1;while (child < n){//child + 1 < n可能没有右孩子,防止越界风险if (child + 1 < n && a[child + 1] < a[child]){child++;}// "<" 和 ">"取决与建立大小堆if (a[child] > a[parent]){swap(&a[child], &a[parent]);parent = child;int child = parent * 2 + 1;}elsebreak;}
}

2.3 堆的插入与堆的删除

//先插入一个数到数组的尾上,再进行向上调整算法,直到满足堆
void HeapPush(HP* php, DataType x)
{assert(php);//判断是否要扩容if (php->size == php->capacity){int newCapacity = php->capacity == 0 ? 4 : php->capacity * 2;DataType* temp = (DataType*)realloc(php->a, newCapacity * sizeof(DataType));if (temp == NULL){perror("realloc fail");return;}php->a = temp;php->capacity = newCapacity;}php->a[php->size] = x;php->size++;AdjustUp(php->a, php->size - 1);
}
//删除堆是删除堆顶的数据,将堆顶的数据根最后一个数据一换,然后删除数组
//最后一个数据,再进行向下调整算法。
void HeapPop(HP* php)
{assert(php);swap(&php->a[0], &php->a[php->size - 1]);php->size--;AdjustDown(php->a, php->size, 0);
}

2.4堆的数据个数与堆的判空和取得堆的堆顶元素

DataType HeapTop(HP* php)
{assert(php);assert(!HeapEmpty(php));return php->a[0];
}
bool HeapEmpty(HP* php)
{assert(php);return php->size == 0;
}int HeapSize(HP* php)
{assert(php);return php->size;
}

http://www.hrbkazy.com/news/32564.html

相关文章:

  • 中小企业网查询旺道seo系统
  • wordpress支付宝移动端seo网站快速排名软件
  • wordpress搭建问答系统seo赚钱暴利
  • 四川省城乡建设部网站首页制作网页链接
  • 怎样做才能提升自己的网站郑州seo技术服务
  • 手机网站制作推广地推
  • 工业贸易企业 营销型网站关键词优化seo多少钱一年
  • 网站下载app连接怎么做企业培训课程视频
  • 重庆网站优化建设建站系统cms
  • 优盖网logo在线设计北京网站优化策略
  • 网站可以放多少视频高级搜索百度
  • 绿茵足球网站建设沈阳疫情最新消息
  • 贵州高端网站建设站长工具中文精品
  • 张家界做网站的百度网盘app官方下载
  • 房地网站制作手机推广app
  • 做网站有什么好的推荐网络营销是做什么
  • 网站建设程序结构seo技术分享免费咨询
  • 网站制作找私人多少钱开发一个app需要多少钱
  • 研究生做网站开发电商培训机构有哪些哪家比较好
  • 无锡做网站选优易信灵宝seo公司
  • 自己做的网站网页错位服装品牌营销策划方案
  • 网站建设 工单网络视频营销策略有哪些
  • wordpress一键迁移网络优化培训骗局
  • wordpress上传文件自动按时间命名龙斗seo博客
  • 深圳seo网站排名优化平台推广费用一般是多少
  • 郑州哪里有做网站的自己搜20条优化措施
  • 制作深圳网站建设新闻投稿
  • 网站优化方法各大网站提交入口网址
  • 微网站建设找哪家公司学生制作个人网站
  • 做平台网站怎么做的厦门网站推广优化哪家好