bzoj4380[POI2015]Myjnie dp
[POI2015]Myjnie
Time Limit: 40 Sec Memory Limit: 256 MBSec Special Judge
Submit: 368 Solved: 185
[Submit][Status][Discuss]
Description
有n家洗车店从左往右排成一排,每家店都有一个正整数价格p[i]。
有m个人要来消费,第i个人会驶过第a[i]个开始一直到第b[i]个洗车店,且会选择这些店中最便宜的一个进行一次消费。但是如果这个最便宜的价格大于c[i],那么这个人就不洗车了。
请给每家店指定一个价格,使得所有人花的钱的总和最大。
Input
第一行包含两个正整数n,m(1<=n<=50,1<=m<=4000)。
接下来m行,每行包含三个正整数a[i],b[i],c[i](1<=a[i]<=b[i]<=n,1<=c[i]<=500000)
Output
第一行输出一个正整数,即消费总额的最大值。
第二行输出n个正整数,依次表示每家洗车店的价格p[i],要求1<=p[i]<=500000。
若有多组最优解,输出任意一组。
Sample Input
1 4 7
3 7 13
5 6 20
6 7 1
1 2 5
Sample Output
5 5 13 13 20 20 13
HINT
Source

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm> #define N 55
#define M 4007
#define maxc 500007
using namespace std; int n,m;
int f[N][N][M],g[N][N][M],h[N][M];
int p[N][N][M],val[N];
int C[M],lsh[maxc],LSH[M],K; inline void up(int &x,const int &y)
{
if(x<y)x=y;
}
struct node
{
int a,b,c;
}a[M];
inline bool cmp(node x,node y)
{
return x.b==y.b?x.a<y.a:x.b<y.b;
}
void pre()
{
sort(a+,a+m+,cmp); sort(C+,C+m+); K=;
for(int i=;i<=m;i++)
if(C[i]!=C[i-]) LSH[++K]=C[i],lsh[C[i]]=K;
for(int i=;i<=m;i++) a[i].c=lsh[a[i].c];
}
void search(int l,int r,int k)
{
if(l>r) return ;
if(!g[l][r][k])
{
for(int i=l;i<=r;i++) val[i]=LSH[k];
return ;
}
for(int i=k;i<=K;i++) if(g[l][r][k]==f[l][r][i])
{
const int pos=p[l][r][i];
val[pos]=LSH[i];
search(l,pos-,i); search(pos+,r,i);
break;
}
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
scanf("%d%d%d",&a[i].a,&a[i].b,&a[i].c),C[i]=a[i].c;
pre();
for(int l=n;l>=;l--)
for(int r=l;r<=n;r++)
{
for(int i=l;i<=r;i++)
for(int j=;j<=K;j++) h[i][j]=;
for(int i=;i<=m&&a[i].b<=r;i++)
{
if(a[i].a<l) continue;
for(int j=a[i].a;j<=a[i].b;j++)
h[j][a[i].c]++;
}
for(int i=l;i<=r;i++)
for(int j=K-;j>=;j--)
h[i][j]+=h[i][j+];
for(int i=l;i<=r;i++)
for(int j=K;j>=;j--)
{
int tmp=g[l][i-][j]+g[i+][r][j]+h[i][j]*LSH[j];
if(f[l][r][j]<tmp) f[l][r][j]=tmp,p[l][r][j]=i;
g[l][r][j]=g[l][r][j+]>f[l][r][j]?g[l][r][j+]:f[l][r][j];
}
}
printf("%d\n",g[][n][]);
search(,n,);
for(int i=;i<=n;i++)
printf("%d ",val[i]);
}
bzoj4380[POI2015]Myjnie dp的更多相关文章
- 2018.10.22 bzoj4380: [POI2015]Myjnie(区间dp)
传送门 区间dp好题. f[i][j][k]f[i][j][k]f[i][j][k]表示区间[i,j][i,j][i,j]最小值为kkk时的最大贡献. 然后可以枚举端点转移. 当时口胡到这儿就不会了. ...
- BZOJ4380 : [POI2015]Myjnie
将$c$离散化,设: $f[i][j][k]$为区间$[i,j]$最小值为$k$的最大收益. $g[i][j][k]$为$\max(g[i][j][k..m])$. $h[i][j]$为对于当前DP区 ...
- BZOJ 4380 [POI2015]Myjnie | DP
链接 BZOJ 4380 题面 有n家洗车店从左往右排成一排,每家店都有一个正整数价格p[i]. 有m个人要来消费,第i个人会驶过第a[i]个开始一直到第b[i]个洗车店,且会选择这些店中最便宜的一个 ...
- 【BZOJ4380】[POI2015]Myjnie 区间DP
[BZOJ4380][POI2015]Myjnie Description 有n家洗车店从左往右排成一排,每家店都有一个正整数价格p[i].有m个人要来消费,第i个人会驶过第a[i]个开始一直到第b[ ...
- 【BZOJ-4380】Myjnie 区间DP
4380: [POI2015]Myjnie Time Limit: 40 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 162 Solved: ...
- 【BZOJ 4380】4380: [POI2015]Myjnie (区间DP)
4380: [POI2015]Myjnie Description 有n家洗车店从左往右排成一排,每家店都有一个正整数价格p[i].有m个人要来消费,第i个人会驶过第a[i]个开始一直到第b[i]个洗 ...
- [POI2015]Myjnie
[POI2015]Myjnie 题目大意: 有\(n(n\le50)\)家洗车店从左往右排成一排,每家店都有一个正整数价格\(d_i\). 有\(m(m\le4000)\)个人要来消费,第\(i\)个 ...
- bzoj [POI2015]Myjnie
[POI2015]Myjnie Time Limit: 40 Sec Memory Limit: 256 MBSec Special Judge Description 有n家洗车店从左往右排成一排, ...
- 【BZOJ】4380: [POI2015]Myjnie
题解 区间dp,先离散化所有价值 \(f[i][j][k]\)表示\([i,j]\)区间里最小值为\(k\)的价值最大是多少 只考虑\(i <= a <= b <= j\)的区间,枚 ...
随机推荐
- Return-to-dl-resolve浅析
本文介绍一种CTF中的高级rop技巧-Return-to-dl-resolve,不久前的0CTF中的babystack和blackhole就用到了这个技巧. 预备知识 在开始本文前希望大家能预先了解一 ...
- Sql中的if函数学习
今天,在修改项目bug时遇到一些需要计算的功能实现,虽然可以用java代码写,但是由于时间较为充裕,有尝试用sql写一下,学习到了if函数 , o.containerSendNet),) transi ...
- P4744 A’s problem(a)
时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试题,每三天结算一次成绩.参与享优惠 描述 这是一道有背景的题目,小A也是一个有故事的人.但可惜的 ...
- 5-1 json模块
1.json.loads(json_str) 把字符串(json串)转成字典 import json # 解析json的 json_str = ''' {"name":" ...
- tp3.2框架中使用volist输出混乱的一点发现
在tp框架中,volist真的是一样很好用的东西,但是要是不注意,用起来也会有问题的 在Controller层中,将数据assign到页面 $this->assign('vo',$news); ...
- Table 分页处理
介绍两种table分页处理:PHP分页 和 js(jquery.table)分页. 一:jquery.table: 1:下载两个文件:table_jui.css 和 jquery.dataTables ...
- HDU 3966 Aragorn's Story 树链拋分
一.写在前面 终于开始开坑link-cut-tree这个了,对于网上找到的大佬的前进路线,进行了一番研发,发现实际上可以实现对于树链拋分的制作.经历了若干长时间之后终于打了出来(为什么每次学什么东西都 ...
- 命令java 找不到或无法加载主类
这个是由于用了package导致cmd下找不到class文件产生的错误,解决方案: 方法1.删除HelloWord.java源程序中的第一行package demo1:然后在cmd下正常使用javac ...
- Android开发——常见的内存泄漏以及解决方案(二)
)Android2.3以后,SoftReference不再可靠.垃圾回收期更容易回收它,不再是内存不足时才回收软引用.那么缓存机制便失去了意义.Google官方建议使用LruCache作为缓存的集合类 ...
- 慢慢琢磨JVM
1 JVM简介 JVM是一个Javaer的最基本功底了,刚开始学Java的时候,一般都是从“Hello World”开始的,然后会写个复杂点class,然后再找一些开源框架,比如Spring,Hibe ...