cf1106E 线性dp+multiset
之前看错题目了,以为父亲的选择时按最大收益来的。结果并不是
/*
注意题目中说只要某个时间父亲可以取得红包,他就取硬币数最多同时耗时最小的那个
就是不管后续如何,不一定满足最大收益
dp[i][j]表示时间i被干扰j次所得的最小收益
dp[i][j]=dp[a+1][j]+b; <a,b>是时间i可取的价值最大同时耗时最小的红包,这是必定取的
dp[i][j]=min(dp[i][j],dp[i+1][j-1])决定是否进行干扰
由状态转移方程可以看出,前面时间的状态是由后面时间的状态取得的,所以外层i循环从后往前
*/
#include<bits/stdc++.h>
#include<set>
#include<vector>
using namespace std;
#define maxn 100005
#define ll long long
ll dp[maxn][],n,m,k;
vector<pair<ll,ll> >S[maxn],E[maxn];
multiset<pair<ll,ll> >s;//默认是从小到大排序的,由于要取出的是价值最大的元素,所以在存入时把w存为-w int main(){
cin>>n>>m>>k;
for(int i=;i<=k;i++){
ll s,t,d,w;
cin>>s>>t>>d>>w;
S[s].push_back(make_pair(-w,-d));
E[t].push_back(make_pair(-w,-d));
} memset(dp,,sizeof dp);
for(int i=n;i>=;i--){
for(int j=;j<E[i].size();j++)s.insert(E[i][j]);
pair<ll,ll> t=make_pair(,);
ll a,b;
if(!s.empty()){
t=*s.begin();
b=-t.first;a=-t.second+;
}
else a=i+,b=;
for(int j=;j<=m;j++){
dp[i][j]=dp[a][j]+b;//未被干扰的决策
if(j)dp[i][j]=min(dp[i][j],dp[i+][j-]);
}
for(int j=;j<S[i].size();j++)s.erase(s.find(S[i][j]));
}
printf("%lld\n",dp[][m]);
}
cf1106E 线性dp+multiset的更多相关文章
- LightOJ1044 Palindrome Partitioning(区间DP+线性DP)
问题问的是最少可以把一个字符串分成几段,使每段都是回文串. 一开始想直接区间DP,dp[i][j]表示子串[i,j]的答案,不过字符串长度1000,100W个状态,一个状态从多个状态转移来的,转移的时 ...
- Codeforces 176B (线性DP+字符串)
题目链接: http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=28214 题目大意:源串有如下变形:每次将串切为两半,位置颠倒形成 ...
- hdu1712 线性dp
//Accepted 400 KB 109 ms //dp线性 //dp[i][j]=max(dp[i-1][k]+a[i][j-k]) //在前i门课上花j天得到的最大分数,等于max(在前i-1门 ...
- 动态规划——线性dp
我们在解决一些线性区间上的最优化问题的时候,往往也能够利用到动态规划的思想,这种问题可以叫做线性dp.在这篇文章中,我们将讨论有关线性dp的一些问题. 在有关线性dp问题中,有着几个比较经典而基础的模 ...
- POJ 2479-Maximum sum(线性dp)
Maximum sum Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 33918 Accepted: 10504 Des ...
- poj 1050 To the Max(线性dp)
题目链接:http://poj.org/problem?id=1050 思路分析: 该题目为经典的最大子矩阵和问题,属于线性dp问题:最大子矩阵为最大连续子段和的推广情况,最大连续子段和为一维问题,而 ...
- nyoj44 子串和 线性DP
线性DP经典题. dp[i]表示以i为结尾最大连续和,状态转移方程dp[i] = max (a[i] , dp[i - 1] + a[i]) AC代码: #include<cstdio> ...
- 『最大M子段和 线性DP』
最大M子段和(51nod 1052) Description N个整数组成的序列a[1],a[2],a[3],-,a[n],将这N个数划分为互不相交的M个子段,并且这M个子段的和是最大的.如果M &g ...
- 『最长等差数列 线性DP』
最长等差数列(51nod 1055) Description N个不同的正整数,找出由这些数组成的最长的等差数列. 例如:1 3 5 6 8 9 10 12 13 14 等差子数列包括(仅包括两项的不 ...
随机推荐
- linux 网络命令
- Django学习手册 - 自定义分页函数
前端代码: <div class="xianshi"> {% for i in info %} <ul> <li>{{ i }}</li& ...
- 不使用setCustomView,设置ActionBar标题居中
仅供参考,有太多自定义标题栏需求时,还是建议使用setCustomView https://blog.csdn.net/chiceT/article/details/50455358
- 为什么可逆矩阵又叫“非奇异矩阵(non-singular matrix)”?
最近在捡回之前的线性代数知识,在复习可逆矩阵的时候,发现有的书上把可逆矩阵又称为非奇异矩阵,乍一看名字完全不知所云,仔细一分析,还是不明白.要想弄明白,还是得从英文入手,下面的解释主要从这里得来的Wh ...
- python opencv3添加opencv-contrib
不需要编译或其他操作,只需一句话安装第三方库利用sift等特征提取算法: sudo pip3 install opencv-contrib-python 附网站:https://pypi.python ...
- 待解决close
关于close语句放在哪里,貌似会对结果产生影响 #include <iostream> #include <fstream> using namespace std; int ...
- 关于第一个java程序HelloWorld的感慨
今天入手第一个java程序,严格意义上来讲,是真正开始研究java的第一个“Hello World": 1.没有用自动提示,虽然System.out.println()还是自动蹦出来了,但是 ...
- LOJ 6277-6280 数列分块入门 1-4
数列分块是莫队分块的前置技能,练习一下 1.loj6277 给出一个长为n的数列,以及n个操作,操作涉及区间加法,单点查值. 直接分块+tag即可 #include <bits/stdc++.h ...
- UVALive 8513 lovers 2017 西安区域赛 B 贪心+multiset
UVALive 8513 有2种人,每个人有自己的权值$A_i$ $B_i$ 当$A_i + B_i >=K$时 两个人可以配对 问最多多少人可以配对 解法 : 把$/{ A_i /}$ 排序 ...
- css3 翻转
参考资料: WEB骇客 : http://www.webhek.com/css-flip/ Demo : Demo(谷歌浏览器观看,没做兼容) Demo截图: 代码: <!DOCTYPE h ...