自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(2)
  • 收藏
  • 关注

原创 C++手写堆的实现(LuoguP3378模板)

关于堆二叉堆有两种形式,分别为大根堆和小根堆。 大根堆有两个性质: 1.根节点点权为所有节点点权中的最大值; 2.任意节点的点权都大于它的子节点. 同样地,小根堆也具有两个性质,并且与大根堆相反: 1.根节点点权为所有点权中的最小值; 2.任意节点的点权都小于它的子节点. 在此仅展示小根堆的实现方法,大根堆与其同理,稍作修改即可。LuoguP3378【模板】堆题目描述如题,初始小根堆为

2017-07-19 18:36:34 4279

原创 倍增法求最近公共祖先(LCA)

思路分析 首先定义一个f[a][b]数组,注意因为b表示的是a向上跳2^b步所到达的点,所以b不需要开得很大,20就足够了。 然后利用邻接表存图,开一个d[]数组利用搜索遍历这张图来记录深度,然后就可以求LCA了。 求LCA时要注意:如果所求的两个点的深度不同,则先让深度大的那个节点向上跳到与另一节点同一高度,再开始让两个点同时跳同样步数。 代码注释很详细,这里就不再详述。#include<

2017-07-17 22:15:09 671

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除