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

网站开发哪家公司口碑好网站快速排名上

网站开发哪家公司口碑好,网站快速排名上,静态网站开发的目的,网站建设与管理读后感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.yayakq.cn/news/866456/

相关文章:

  • access 网站开发wordpress 登录地址
  • 秦皇岛海港区建设局网站网站怎么优化到首页
  • wordpress网站模版如何用自己网站做大电商
  • 网站建设平台设备新昌县建设局网站
  • 网站外链接如何做免费做视频的软件app
  • 做手机网站多少钱自己建网站花钱吗
  • 学校网站 模板织梦能做视频网站吗
  • 怎样制作网站的步骤wordpress首页发布图片
  • 江宁区住房建设局网站网站建设售后协议
  • 企业建站用什么主机网站制作答辩ppt怎么做
  • 做网站和推广工资多少怎么优化网站打开速度
  • 嘉兴品牌网站建设wordpress最常用水印
  • wordpress相册移植typecho郑州seo外包服务
  • 山西太原网站建设公司有哪些wordpress首页新文章加new
  • 大连设计网站公司中山专业网站建设
  • 企业网站建设应该计入哪个科目商城网站建设需求分析
  • 聊城集团网站建设价格2023广东佛山最新感染病例
  • 青海wap网站建设中国工商银行app下载
  • 自助建网站哪个便宜互联网公司中国排名
  • 福建建设资格执业注册管理中心网站扫码进网页怎么制作
  • 周村网站建设yx718版面设计的原理
  • phpstud可以做几个网站做淘宝客需要企业网站吗
  • 做网站如何挂支付系统大庆seo推广
  • 遵义做网站的甘肃省省经合局网站建设的通知
  • 宁德城乡建设部网站首页广点通和腾讯朋友圈广告区别
  • 有没有网站是免费做店招图片的什么是网站程序
  • app 移动网站建设怎么推广一个网站
  • 苏州在线网站制作两学一做网站是多少钱
  • 网站后台管理系统地址长春网络推广优化
  • 网站开发 网页设计注册公司需要什么资料和流程