Codeforces 1107F(dp)
怎么就没人解释一下为啥用b排序可以保证正确性呢……太菜了,理解了好久。
时间流逝价值会丢失的背包,类似题洛谷1417
本题与洛谷1417不同之处在于流逝是有截止的。
1.这个dp[j]的含义是:最后跑路时欠了j个费所得到的最大钱数。
2.假设是不排序的,直接去背包,考虑两种转移,一种是选了当前这个以后到最后时欠的个数并不增多(即这个的k天都还了);另一种是这个也没还完。
3.如果直接都还了那顺序完全无所谓了,但是如果有这么几个都是最后要欠的,那么显然第一个要支付0天(即提钱当天就跑路了),第二个要支付1天,……第j个支付(j - 1)天。那么无论列一列式子(如洛谷1417)还是直观感受,反正就是这么几个,那肯定贪心地、尽量少扣大的b。这就是要按b从大到小排序的原因。
4.取dp[0~n]的最大值。
const int maxn = ;
int n;
struct off {
ll a, b, k; bool operator < (const off &rhs) const {
return b > rhs.b;
}
}offer[maxn];
ll dp[maxn]; int main() {
cin >> n;
rep(i, , n) cin >> offer[i].a >> offer[i].b >> offer[i].k; sort(offer + , offer + + n);
rep(i, , n) {
irep(j, i, ) {
dp[j] = max(dp[j], dp[j] + offer[i].a - offer[i].b * offer[i].k);
if (j) dp[j] = max(dp[j], dp[j - ] + offer[i].a - offer[i].b * (j - ));
}
} cout << *max_element(dp, dp + n + ) << endl;
return ;
}
Codeforces 1107F(dp)的更多相关文章
- Codeforces 1142D(dp)
		题目传送 先给出设计dp的结论: dp[i][j]:以第i个位置.以rankj的数拓展出去的方案数.意会一下,我实在想不好语言-- 其中所谓rankj=真·rank%11 找到拓展的规律,转移也就顺理 ... 
- Codeforces 1131G(dp)
		传送门 与Codeforces1107G一起食用 思路 想到要用dp--然后常规地设dp[i]为推倒前i个牌的最小花费 有两种情况:一是当前这个推,二是不推而被别人推.对于第一种,需要找到这个左推(因 ... 
- Codeforces 1107G(dp)
		1.答案要取连续的区间疯狂暗示线段树. 2.外层枚举r,内层枚举l显然过于暴力. 3.考虑内层的优化.dp[i]:以第i位为结尾的答案(长度大于1的).dp[i] = max(第一种情况,第二种情况) ... 
- codeforces 682D(DP)
		题目链接:http://codeforces.com/contest/682/problem/D 思路:dp[i][j][l][0]表示a串前i和b串前j利用a[i] == b[j]所得到的最长子序列 ... 
- codeforces 666A (DP)
		题目链接:http://codeforces.com/problemset/problem/666/A 思路:dp[i][0]表示第a[i-1]~a[i]组成的字符串是否可行,dp[i][1]表示第a ... 
- Codeforces 1144G(dp)
		据说这题是种dp的套路?然后被我国红名神仙(南大Roundgod)贪心了,不过思路上非常相近了,故而可贪吧. 设的dp[i][0]是:如果把第i个数放在上升序列里了,那么下降序列结尾的那个最大是多少: ... 
- Codeforces 1152D(dp)
		要点 寻找最多边的匹配的结论:贪心地从叶子开始找,最后答案都是奇数层下边的那条边. 设\(dp[i][j]\)表示当前长度为\(i\),平衡度为\(j\),平衡度为(数量减去)数量. 增加左右括号转移 ... 
- Three displays CodeForces - 987C (dp)
		C. Three displays time limit per test 1 second memory limit per test 256 megabytes input standard in ... 
- LightOJ 1033  Generating Palindromes(dp)
		LightOJ 1033 Generating Palindromes(dp) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ... 
随机推荐
- Linux服务器Java输出文件中文乱码
			使用下面语句查看编码: String encoding = System.getProperty("file.encoding");结果输出:ANSI_X3.4-1968,从而导致 ... 
- Windows Power Shell
			Windows PowerShell 是一种命令行外壳程序和脚本环境,使命令行用户和脚本编写者可以利用 .NET Framework的强大功能. 它引入了许多非常有用的新概念,从而进一步扩展了您在 W ... 
- mongodb压缩——snappy、zlib块压缩,btree索引前缀压缩
			MongoDB 3.0 WiredTiger Compression and Performance One of the most exciting developments over the li ... 
- maven中常用命令
			1. 更新本地仓库, 首先确认C:\users\pengqiong\ 路径下有相应的pom文件 mvn clean package install: 
- <编程>比较两种素数表生成算法+计算程序运行时间+通过CMD重定向测试程序
			最近学习加密算法,需要生成素数表,一开始使用简单的循环,从2开始判断.代码如下: #include<iostream> #include<cstdio> #include< ... 
- AutoIt: 如何使用 AutoIt 解析,修改XML 文件
			项目组这次要发布一个项目,需要实施人员根据现场的机器情况,修改项目配置文件的几个节点,为了减轻实施人员的工作负担,我应用AutoIt写了一个小界面,实施人员只需在该界面上点几个按钮,就能够完成文件的配 ... 
- poj 2420 A Star not a Tree? —— 模拟退火
			题目:http://poj.org/problem?id=2420 给出 n 个点的坐标,求费马点: 上模拟退火. 代码如下: #include<iostream> #include< ... 
- win7 第一次装 mysql-5.7.16-winx64 ,不知道root 密码,该如何处理?
			转载请注明出处:http://blog.csdn.net/qq_26093511/article/details/52851811 ERROR 1045 (28000): Access denied ... 
- A - Toy Cars
			Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Description Little ... 
- Android开发相关工具(eclipse篇)
			ADT 安装该工具后才能配置Android SDK包,使可以在eclipse里开发Android程序 AVD Android模拟器管理工具,创建删除Android模拟器 SDK Manager And ... 
