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

原创 Usaco Cowlphabet,2011 Feb 奶牛文字

解析: 一看题就有一个answer取97654321的余数要求,那正解肯定不会是dfs或者暴力之类的了。 正解为方案数类dp,灵感来自于字母和大小写的个数。因为当我们递推时,我们无需知道具体的序列,只需知道序列中有几个大小写字母,以及此序列末尾字母是什么(用来找下一个字母)就可以了。 具体方法: 用f[i][j][k] 表示末尾字母的ascll码为i,大写字母有j个,小写字母有k个的字串

2017-03-25 20:31:51 560

原创 Usaco Financial Aid,2004 Mar 赞助学费

分析: 很巧妙的一个堆维护+枚举。 在对成绩排序后,我们无需知道一个成绩中位数左右两侧的选择具体是谁,只需知道左右两侧各取n/2个(保证其为中位数)时学费最小和就可以判断此数是否符合题意。 具体操作: 设两个数组L[i],R[i]分别表示到当前位置i时左边取n/2个数的和的最小值和右边取n/2个数的和的最小值,也就是说,答案就是当L[i]+R[i]+i的学费成立的i的最大值。

2017-03-25 20:12:03 662

空空如也

空空如也

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

TA关注的人

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