百度SEO

百度SEO

Products

当前位置:首页 > 百度SEO >

中国海峡建设公司官网如何进行设计开发建设?

96SEO 2026-02-19 21:57 2


(以大堆为例)1、堆的定义2、堆的初始化3、堆的销毁4、堆的打印5、堆的插入6、堆顶元素的获取7、堆的删除8、堆元素个数的获取8、堆的判空10、堆简单的应用三、堆的创建1、向上调整建堆2、向下调整建堆四、堆的应用1、堆排序2、TOP-K问题一、二叉树的顺序结构及实现

中国海峡建设公司官网如何进行设计开发建设?

普通的二叉树是不适合用数组来存储的因为可能会存在大量的空间浪费。

而完全二叉树更适合使用顺序结构存储。

现实中我们通常把堆(一种二叉树)使用顺序结构的数组来存储需要注意的是这里的堆和操作系统虚拟进程地址空间中的堆是两回事一个是数据结构一个是操作系统中管理内存的一块区域分段。

k0k1k2..kn−1k_0k_1

}把它的所有元素按完全二叉树的顺序存储方式存储在一个一维数组中并满足:

KiK2i1K_i

K_{2i1}Ki​K2i1​且Ki;K2∗i2(KiK2i1且KiK2∗i2)i01⋅⒉...K_i;

K_{2*i2}(K_i

i01·⒉...Ki​;K2∗i2​(Ki​K2i1​且Ki​K2∗i2​)i01⋅⒉...则称为小堆(或大堆)。

将根节点最大的堆叫做最大堆或大根堆根节点最小的堆叫做最小堆或小根堆。

大堆树中所有父亲都大于等于孩子

在前一篇文章中我们也讲过,左孩子都是奇数右孩子都是偶数并且孩子和父亲下标也是有一定关系的我们也可以通过找规律得到下面的关系:

leftchild

//偶数会被取整数因此可以直接按照左孩子公式反推二、堆的简单实现

由于堆比较适合用数组存储我们可以按照顺序表的结构来进行定义但是切记数组存储是物理结构我们要把这个物理结构给抽象为完全二叉树。

typedef

堆的初始化我们可以给指针a开辟空间,也可以不开辟空间这里选择不开辟空间。

void

堆的销毁我们可以直接将空间进行释放然后将指针置空size与capacity置成0就行了。

void

由于我们是使用数组实现堆我们可以直接遍历一遍数组将它们打印出来就行了。

void

堆的插入就有一些复杂了我们的插入数据以后要保证插入数据后的堆还是一个大堆不然就破坏了堆的结构。

我们先来考虑第一种情况

①首先在我们插入数据子节点之前原始堆就要满足堆的结构否则就是前面的代码出现了问题与我们插入的数据无关

②然后插入的子节点要与其父节点进行比较如果小于其父节点则不交换正常插入。

如果其插入的子节点大于父节点就要进行向上调整交换这个交换次数是不确定的可能是一次也可能是两次不过最多就是树的高度hlog⁡2Nh\log_2Nhlog2​N次(NNN为节点个数),这也就是说我们的堆的插入是时间复杂度是O(log⁡2n)O(\log_2n)O(log2​n)

接下来就是我们要根据这两种情况写出相应的代码了这个时候这个孩子和父亲下标关系就很重要了,通过这个关系我们就能由子节点找到父节点由父节点找到子节点了。

void

sizeof(HPDateType)*new_capacity);//realloc对于没有进行动态内存分配过的指针

调用会相当与一次mallocif

new_capacity;}//数据插入php-a[php-size]

data;php-size;//向上调整AdjustUp(php-a,php-size-1);

}其中向上调整算法非常重要

//child0说明子节点已经调整到了堆顶已经不需要再进行调整了。

{if

(a[child]

//更改父节点的下标方便继续与下面新的子节点比较}else{break;//比较不满足条件说明数据经过调整后已经符合大堆了}}

对于堆来说堆顶的数据一定是堆里面最大或最小的数所以堆顶数据的获取还是很有必要的它的实现也并不复杂。

HPDateType

对于堆的删除一般是删除堆顶元素因为除了堆顶元素其他元素删除的意义并不大但是堆顶的元素删除又会破环堆的结构。

而且如果采用直接删除堆顶元素其他元素向前挪动之后再进行调整的话会有很大的浪费因为数组向前挪动的时间复杂度是O(n)O(n)O(n)。

但是数组的尾删效率很高是O(1)O(1)O(1),所以数组尽量进行尾删。

于是便有了一种良好的先交换再向下调整的算法它的思想是先让堆顶元素与最后一个元素交换位置这样原先的堆顶元素就变成了堆底元素然后删除堆底元素再对堆顶的元素进行向下调整其核心算法就在于向下调整。

向下调整算法

向下调整算法要求我们先取堆顶元素的子节点中较大的那个与堆顶元素进行比较如果子节点大于父节点就进行交换然后父节点的下标变到原先子节点的下标再次执行上面的步骤取父节点下面较大的子节点进行比较换位…

void

1]);php-size--;//向下调整AdjustDown(php-a,php-size,0);

}向下调整算法

a[parent]){Swap(a[child],a[parent]);parent

child;child

}向下调整的算法与向上调整类似这个交换次数是不确定的可能是一次也可能是两次不过最多就是树的高度hlog⁡2Nh\log_2Nhlog2​N次(NNN为节点个数),这也就是说我们的堆的删除是时间复杂度也是O(log⁡2n)O(\log_2n)O(log2​n)

比较一下向上调整算法与向下调整算法

向上调整算法要求数据插入之前原先的数据已经是一个堆了才能重新建堆。

向下调整算法的要求左右子树必须是一个堆才能调整重新建堆。

int

堆顶的元素是最大小的元素我们可以取堆顶K次删除K次拿到一个数据集中最大小的前K个。

int

//打印堆中的元素printf(\n);//选出最大的前五个int

5;for

//删除堆顶元素重新定位新的最大的。

}HeapDestroy(hp);

排序问题

arr[i]);}HeapPrint(hp);printf(\n);//排序while(!HeapEmpty(hp))//只要不为空就一直进行排序。

{printf(%d

HeapTop(hp));HeapPop(hp);}HeapDestroy(hp);return

在上面的代码中我们看到我们经常会用一个数组去创建堆因此我们还是很有必要再写一个函数——堆的创建在上面的代码中我们创建一个堆其实是用的是堆的插入即将数据插入到数组最后再进行向上调整。

这种方法能帮我们完成堆的创建但是它的效率并不是很高我们可以对其做一定优化。

1、向上调整建堆

(HPDateType*)malloc(sizeof(HPDateType)

n);if

按照最坏的情况来算完全二叉树的最坏情况是满二叉树且每个节点都要调整

向上调整建堆的第一层是不进行调整的设FFF是建堆交换调整的总次数h−1h-1h−1是树的高度NNN是树的结点个数,则有

F21∗122∗223∗3......2h−2∗h−22h−1∗h−1F2^1*12^2*22^3*3......2^{h-2}*h-22^{h-1}*h-1

F21∗122∗223∗3......2h−2∗h−22h−1∗h−1

利用错位相减法得

N20212223......2h−22h−12h−1(2)N2^02^12^22^3......2^{h-2}2^{h-1}2^h-1\tag{2}

将2带入1中得

F(N1)∗(log⁡2(N1)−2)1(3)F(N1)*(\log_2{(N1)}-2)1\tag{3}

因此向上调整建堆的时间复杂度是O(nlog⁡2n)O(n\log_2n)O(nlog2​n)

2、向下调整建堆

向下调整算法是有的要求的左右子树必须是一个堆才能调整重新建堆但给我们的数组本身就是乱序的那我们应该怎样才能保证左右子树是一个堆呢

答案是我们从倒数的第一个非叶子节点的子树开始调整一直调整到根节点的树就可以调整成堆。

在这里第一个非叶子节点的子树是28,我们可以通过子节点与父节点的关系找到28的下标然后向下调整让①区域变成堆然后下标减一到18的位置然后向下调整让②区域变成堆然后下标减一到19的位置然后向下调整让③区域变成堆…直到下标为零时再调整一次这样就把堆给建立起来了。

代码实现

(HPDateType*)malloc(sizeof(HPDateType)

n);if

sizeof(HPDateType)*n);//内存拷贝函数for

(int

//利用向下调整算法}}这种建堆算法效率是比较高的我们来求一下它的时间复杂度。

按照最坏的情况来算完全二叉树的最坏情况是满二叉树且每个节点都要调整

由于向下调整建堆是从倒数第二层开始调整的所以我们假设树的高度为hhh,FFF是建堆交换调整的总次数NNN是树的结点个数。

F2h−2∗12h−3∗22h−4∗3......21∗h−220∗h−1(1)F2^{h-2}*12^{h-3}*22^{h-4}*3......2^1*h-22^0*h-1\tag{1}

F2h−2∗12h−3∗22h−4∗3......21∗h−220∗h−1(1)

利用错位相减法得

N20212223......2h−22h−12h−1(2)N2^02^12^22^3......2^{h-2}2^{h-1}2^{h}-1\tag{2}

将2带入1中得

FN−(log⁡2(N1)1)(3)FN-(\log_2{(N1)}1)\tag{3}

FN−(log2​(N1)1)(3)

对比我们也可以发现向上调整算法是那一层节点越多向上调整越多而向下调整算法是那一层节点越少向下调整越多。

因此向下调整算法更加优秀

1、堆排序

但是上面的应用我们都是借助了堆这个数据结构利用了堆的插入与删除在实际应用时给你一个数组让你进行排序难道我们还要费很大的力气去建堆这样显然太慢了所以我们需要找到一种不用建立堆的数据结构就能进行排序的算法。

首先经过前面的学习我们都知道了每个连续存储的数组可以看成一个完全二叉树因此我们可以利用刚才堆的创建的思路对数组里面的数据进行建堆然后进行排序。

假设我们建立小堆的话第一个元素就不用进行排序了我们从第二个进行排序但是从第二个元素开始重新排序的话我们的堆结构可能就被破坏了不利于我们后续选数据要不就是遍历一遍选一个数这些效率都不太好。

因此小堆并不适合建立升序数组。

我们再来看看大堆

我们可以将堆顶元素与堆底元素进行换位这样我们最大的元素就到了正确的位置然后对堆顶元素向下调整一次便可以重新建堆因为左子树与右子树关系没有改变再然后把最后一个元素不看成堆里面的元素再将堆顶元素与堆底元素进行换位这样我们次大的元素就到了正确的位置然后对堆顶元素向下调整一次便可以重新建堆再然后把最后两个元素不看成堆里面的元素如此继续循环往复等数组里面的数被遍历一遍后排序也就结束了另外我们向下调整一次最多交换高度次log⁡2n\log_2nlog2​n,因此堆排序的时间复杂度是O(nlog⁡2n)O(n\log_2n)O(nlog2​n)。

//堆排序

--Onwhile(parent0){AdjustDown(arr,

--O(nlogn)int

arr[end]);//向下调整重新建堆AdjustDown(arr,

end,

在前面堆的简单应用中我们也简单的学习了用堆的数据结构进行解决TOP-K问题我们建立一个大堆对堆顶元素进行删除拿到第一个数据再重新向下调整建堆再对堆顶元素进行删除拿到第二个数据…如此往复便解决了TOP-K的问题。

但是一般情况下TOP-K问题的数据量都比较大我们再利用上面的方法可能就不太行了例如从100亿个数据中选择10个最大的假设全是整数那么需要400亿字节而1G≈10亿字节我们用数组存储这100亿个数就需要40G的内存这显然内存不足于是我们就需要把这么多的数据放进硬盘中了利用文件读取来读取数据可是硬盘中的数据并不能建堆于是我们就要考虑其他的算法了。

我们可以建立一个KK为要想要选取的数的个数个数据的小堆从文件中读取数据与堆顶的元素进行比较如果大于堆顶元素就替换掉堆顶元素然后向下调整重新建立小堆这样经过遍历所有数后想要的K个数就在小堆里面

代码示例

fail:);return;}//设置随机种子srand(time(NULL));int

val

i){//插入5个明显更大的数据方便判断TOP-K结果是否正确if

randK

i);randK--;continue;}//造500个随机数val

rand()

val);}//关闭文件fclose(pfin);//以读的方式打开文件FILE*

pfout

0);}}fclose(pfout);//打印堆中的数据for

(int



SEO优化服务概述

作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。

百度官方合作伙伴 白帽SEO技术 数据驱动优化 效果长期稳定

SEO优化核心服务

网站技术SEO

  • 网站结构优化 - 提升网站爬虫可访问性
  • 页面速度优化 - 缩短加载时间,提高用户体验
  • 移动端适配 - 确保移动设备友好性
  • HTTPS安全协议 - 提升网站安全性与信任度
  • 结构化数据标记 - 增强搜索结果显示效果

内容优化服务

  • 关键词研究与布局 - 精准定位目标关键词
  • 高质量内容创作 - 原创、专业、有价值的内容
  • Meta标签优化 - 提升点击率和相关性
  • 内容更新策略 - 保持网站内容新鲜度
  • 多媒体内容优化 - 图片、视频SEO优化

外链建设策略

  • 高质量外链获取 - 权威网站链接建设
  • 品牌提及监控 - 追踪品牌在线曝光
  • 行业目录提交 - 提升网站基础权威
  • 社交媒体整合 - 增强内容传播力
  • 链接质量分析 - 避免低质量链接风险

SEO服务方案对比

服务项目 基础套餐 标准套餐 高级定制
关键词优化数量 10-20个核心词 30-50个核心词+长尾词 80-150个全方位覆盖
内容优化 基础页面优化 全站内容优化+每月5篇原创 个性化内容策略+每月15篇原创
技术SEO 基本技术检查 全面技术优化+移动适配 深度技术重构+性能优化
外链建设 每月5-10条 每月20-30条高质量外链 每月50+条多渠道外链
数据报告 月度基础报告 双周详细报告+分析 每周深度报告+策略调整
效果保障 3-6个月见效 2-4个月见效 1-3个月快速见效

SEO优化实施流程

我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:

1

网站诊断分析

全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。

2

关键词策略制定

基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。

3

技术优化实施

解决网站技术问题,优化网站结构,提升页面速度和移动端体验。

4

内容优化建设

创作高质量原创内容,优化现有页面,建立内容更新机制。

5

外链建设推广

获取高质量外部链接,建立品牌在线影响力,提升网站权威度。

6

数据监控调整

持续监控排名、流量和转化数据,根据效果调整优化策略。

SEO优化常见问题

SEO优化一般需要多长时间才能看到效果?
SEO是一个渐进的过程,通常需要3-6个月才能看到明显效果。具体时间取决于网站现状、竞争程度和优化强度。我们的标准套餐一般在2-4个月内开始显现效果,高级定制方案可能在1-3个月内就能看到初步成果。
你们使用白帽SEO技术还是黑帽技术?
我们始终坚持使用白帽SEO技术,遵循搜索引擎的官方指南。我们的优化策略注重长期效果和可持续性,绝不使用任何可能导致网站被惩罚的违规手段。作为百度官方合作伙伴,我们承诺提供安全、合规的SEO服务。
SEO优化后效果能持续多久?
通过我们的白帽SEO策略获得的排名和流量具有长期稳定性。一旦网站达到理想排名,只需适当的维护和更新,效果可以持续数年。我们提供优化后维护服务,确保您的网站长期保持竞争优势。
你们提供SEO优化效果保障吗?
我们提供基于数据的SEO效果承诺。根据服务套餐不同,我们承诺在约定时间内将核心关键词优化到指定排名位置,或实现约定的自然流量增长目标。所有承诺都会在服务合同中明确约定,并提供详细的KPI衡量标准。

SEO优化效果数据

基于我们服务的客户数据统计,平均优化效果如下:

+85%
自然搜索流量提升
+120%
关键词排名数量
+60%
网站转化率提升
3-6月
平均见效周期

行业案例 - 制造业

  • 优化前:日均自然流量120,核心词无排名
  • 优化6个月后:日均自然流量950,15个核心词首页排名
  • 效果提升:流量增长692%,询盘量增加320%

行业案例 - 电商

  • 优化前:月均自然订单50单,转化率1.2%
  • 优化4个月后:月均自然订单210单,转化率2.8%
  • 效果提升:订单增长320%,转化率提升133%

行业案例 - 教育

  • 优化前:月均咨询量35个,主要依赖付费广告
  • 优化5个月后:月均咨询量180个,自然流量占比65%
  • 效果提升:咨询量增长414%,营销成本降低57%

为什么选择我们的SEO服务

专业团队

  • 10年以上SEO经验专家带队
  • 百度、Google认证工程师
  • 内容创作、技术开发、数据分析多领域团队
  • 持续培训保持技术领先

数据驱动

  • 自主研发SEO分析工具
  • 实时排名监控系统
  • 竞争对手深度分析
  • 效果可视化报告

透明合作

  • 清晰的服务内容和价格
  • 定期进展汇报和沟通
  • 效果数据实时可查
  • 灵活的合同条款

我们的SEO服务理念

我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。

提交需求或反馈

Demand feedback