自定义博客皮肤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)
  • 收藏
  • 关注

原创 Codeforces gym101981 (2018 icpc 南京站) B.Tournament

一条直线上有N个村庄,要在这条直线上选K个地方建雕像,使得每个村庄到离其最近的雕像的距离的和最小。输出最小的和。(范围1e5)首先考虑一堆村庄建一个雕像,则最优方案一定是放在中间的村庄(偶数的话中间两个都可以)那么考虑最优方案一定被包含于,所有的把整个序列划分成k段,并在每段中挑选中间位置建雕像的方案。可以dp,dp到某个位置i建了j个雕像的最小代价。转移dp(i,j) = min { dp(x,j - 1)+ cost(i,j)}cost是i,j这一段在中间建雕像的代价,可O(1)查询

2020-12-25 23:39:52 312

原创 Codeforces Educational Codeforces Round 95 G. Three Occurrences

给定一个序列,求所有子区间满足任何一个值出现次数恰好为3次。1.一种容易想到的解法:可行区间问题,考虑固定区间左端点,查询此时有多少个右端点满足要求。首先令l = n, 此时可行右端点为0.考虑l' = l - 1, l’上的值是x,则可以发现x上上上次出现位置右侧一律不能再作为右端点,而上上次出现到上上上次出现位置变得可能成为右端点。发现是一个类似区间修改的问题,考虑用线段树维护。初始,令线段树上所有点的值为0,对于某一个值的对某段区间标记为不可行的修改,将该区间值-1;对于某一个

2020-12-25 22:43:22 262 1

空空如也

空空如也

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

TA关注的人

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