摘要: 题目传送门 这是一道并查集的题目,相信很多人都看出来了。 用一个类似Kurskal的东西求出最近的最大值。 对于一些可以划分在同一个部落里的边,我们一定是优先选择短边合并。 code: 阅读全文
posted @ 2017-09-25 21:49 Cptraser 阅读(264) 评论(0) 推荐(0)
摘要: 题目传送门 这是一道贪心的问题。 总体做法是这样的:先按照报废的快慢从小到大SORT一遍,优先修报废快的。同时开一个大根堆(C++的朋友可以用priority_queue),用来记录已经修了的建筑的耗时大小。 在优先修建筑的时候,如果在当前所用的时间加上修的时间超过了报废时间了的话,就找出大根堆的T 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(112) 评论(0) 推荐(0)
摘要: 回文词 (palin.pas/c/cpp) 【问题描述】 回文词是一种对称的字符串——也就是说,一个回文词,从左到右读和从右到左读得的结果是一样的。任意给定一个字符串,通过插入若干字符,都可以变成一个回文词。你任务是写一个程序,求出将给定字符串变成回文词所需插入的最少字符数。比如字符串“Ab3bd” 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(847) 评论(0) 推荐(0)
摘要: 题目传送门 这是一道单调栈的问题,单调栈维护所有数的最大值。 查询操作时只需要二分找答案即可,枚举栈内的数应该也不会超时。 code: /************************************************************** Problem: 1012 User 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(107) 评论(0) 推荐(0)
摘要: 最短路径例题 今天特地学习了Dijkstra的堆优化(主要是慕名已久)。 我们需要一个堆来记录[编号,到编号这个点的最短路径值(当然只是当前的)] 与原来的Dijkstra操作基本一致,主要有以下几点: 1.将起点放入堆中 2.开始while循环 3.取出堆顶 4.如果已经拓展过就continue 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(275) 评论(0) 推荐(0)
摘要: 题目传送门 带权并查集问题。 用fr[x]数组记录x战舰前(不包括自己)有几艘战舰,beh[x]数组记录x战舰后(包括自己)有几艘战舰。 并查集即可。 code: #include <cstdio> #include <cmath> #include <iostream> using namespa 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(109) 评论(0) 推荐(0)
摘要: 题目传送门 又是一道BZOJ的水题。 DP,F[i]表示第i只鼹鼠出现后可以砸几只。 F[i]=max(F[i],F[j]+1); 但要满足time[i]-time[j]>=abs(x[i]-x[j])+abs(y[i]-y[j]) code: /************************** 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(97) 评论(0) 推荐(0)
摘要: 没有上司的舞会 1380 没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目描述 Description Ural大学有N个职员,编号为1~N。他们有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司。每个职员有一个快乐指数。现在有个周年庆宴会,要求 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(122) 评论(0) 推荐(0)
摘要: 转自YXDs 题目传送门 不知道今天是怎么了,可能是空调吹多了吧,一直不在状态,连递推题我都做不来了……(扎Zn了老Fe……) 然而,不管环境如何恶劣,我们仍要努力学习,为了自己的明天而奋斗。(说的好像跟真的一样) 其实这题就是一个递推,现在我们考虑第i个数,定义f[i][j]表示序列里有i个数,逆 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(182) 评论(0) 推荐(0)
摘要: 题目传送门 我不得不说这是一道BZOJ的大水题。 一眼就可以看出的布尔型DP。 F[i][j]表示前i天能否达到j音量。 code: #include <cstdio> #include <cctype> #define C c = tc ( ) using namespace std; inlin 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(137) 评论(0) 推荐(0)
摘要: 中位数的和 (number.pas/c/cpp) 【题目描述】 flower 有 N-1 个朋友,他们要一起玩一个游戏:首先确定三个非负整数 a,b,c,然后每个人依次在纸上写一个数,设第 i 个人写下的数字为 f[i],flower 先写下数字 f[1]=1,对于第 i 个写数字的人(i>1)有: 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(194) 评论(0) 推荐(0)
摘要: Piggy Back (piggyback.pas/c/cpp) 【问题描述】 Bessie 和她的姐姐 Elsie 在不同的田块吃草,晚上她们都返回牛棚休息。作为聪明的奶牛,她们想设计一个方案使得步行消耗的能量最少。牛,她们想设计一个方案使得步行消耗的能量最少。Bessie 从一个田块到相邻的田块 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(247) 评论(0) 推荐(0)
摘要: WILL 吃桃 (peach.pas/c/cpp) 【 题目描述】 Will 很喜欢吃桃, 某天 Will 来到了一片森林, 森林中有 N 颗桃树, 依次编号为 1,2,„,N.每棵树上有数量不等的桃子。 某些桃树之间有单向通行的小路, 且路径不会形成环, 通过每条小路的时间也不一定相同。 现在, 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(261) 评论(0) 推荐(0)
摘要: 一下子又过去了≥7天(据上一次总结)。 在这几天中,我们刷了许多题,有水题也有难题,我们积累了很多经验。首先是: 要记得开long long。 要记得开long long。 要记得开long long。 这很重要,所以要说三遍。 在这几天中,我们不仅在判断题目的类型上功力大增,而且也对一些算法和数据 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(191) 评论(0) 推荐(0)
摘要: 题目传送门 这是一道典型的记忆化搜索题。 f[x][y]表示以x,y为右下角的方案数。 code: #include <cstdio> #define mod 1000000007 using namespace std; int n,m,k,a[751][751],f[751][751]; int 阅读全文
posted @ 2017-09-25 19:16 Cptraser 阅读(142) 评论(0) 推荐(0)