【JZOJ4710】【NOIP2016提高A组模拟8.17】Value
题目描述
输入
输出
样例输入
5 
8 2 
10 7 
5 1 
11 8 
13 3
样例输出
27
数据范围
解法
选定一些物品a[1],a[2],a[3]…a[num],尝试交换a[i],a[j],那么对答案的贡献是: 
-(v[i]-xsum)-(v[j]-w[i]-xsum)+(v[j]-xsum)+(v[i]-w[j]-xsum) (xsum为sigma(w[1..i-1])); 
整理后可得+w[i]-w[j],所以说如果w[i]>w[j],那么我们交换a[i],a[j]是对答案有积极贡献的。 
所以我们以w为关键字从小到大排序,然后就变成了经典的背包问题。 
但是直接套上背包会超时,只可以拿40%的分。 
接下来会有两个选择支:
A.优化背包,去除冗余状态
排序后,经典背包是这样的f[j+w[i]]=max{f[j]+v[i]-j}; 
如果想让f[j]对f[j+w[i]]做出贡献,那么就必须保证v[i]-j>0,所以所以枚举j时不能超过v[i]。
B.更改动态规划方法(标准解法)
排序后,设f[i][j]表示倒序动态规划到了第i个物品,已经选了j个物品。 
那么f[i][j]=max{f[i+1][j],f[i+1][j-1]+v[i]-j*w[i]} 
这样就利用了选择一个物品只会对这个物品后的其他物品造成影响的性质。 
时间复杂度为O(n^2)。
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define ll long long
#define sqr(x) ((x)*(x))
#define ln(x,y) int(log(x)/log(y))
using namespace std;
const char* fin="aP2.in";
const char* fout="aP2.out";
const int inf=0x7fffffff;
const int maxn=5007,maxm=100007;
int n,i,j,k,maxa,ans;
struct node{
    int v,w;
}a[maxn];
int f[maxn][maxn];
bool cmp(node a,node b){
    return a.w<b.w;
}
int main(){
    scanf("%d",&n);
    for (i=1;i<=n;i++){
        scanf("%d%d",&a[i].v,&a[i].w);
        maxa=max(maxa,a[i].v);
    }
    sort(a+1,a+n+1,cmp);
    for (i=n;i>0;i--){
        for (j=1;j<=n;j++){
            f[i][j]=max(f[i+1][j],f[i+1][j-1]-a[i].w*(j-1)+a[i].v);
            ans=max(ans,f[i][j]);
        }
    }
    printf("%d",ans);
    return 0;
}启发
1.尝试优化动态规划的冗余状态,剔除不必要的转移。 
2.挖掘题目性质,顺着性质设置状态。
【JZOJ4710】【NOIP2016提高A组模拟8.17】Value的更多相关文章
- 【JZOJ4787】【NOIP2016提高A组模拟9.17】数格子
		题目描述 输入 输出 样例输入 1 10000 3 10000 5 10000 0 0 样例输出 1 11 95 数据范围 每个测试点数据组数不超过10组 解法 状态压缩动态规划. 设f[i][j]表 ... 
- 【NOIP2016提高A组模拟9.17】序列
		题目 分析 首先用\(a_i\)表示达到目标的步数\(B_i-A_i(mod 4)\) 根据粉刷栅栏,先不管mod 4的情况,答案就是\(\sum\max(a_i-a_{i+1},0)\) 那我们刚才 ... 
- NOIP2016提高A组模拟9.17总结
		第一题,典型的隔板问题, 但是我忘记隔板问题怎么打,一开始在花了1小时,还是没想出来,果断弃疗, 最后的40分钟,我打完了第二题,接着又用了20分钟推敲出一种极其猥琐的式子来代替,可惜预处理的阶乘忘记 ... 
- 【NOIP2016提高A组模拟9.17】数格子
		题目 分析 设表示每一行的状态,用一个4位的二进制来表示,当前这一行中的每一个位数对下一位有没有影响. 设\(f_{i,s}\)表示,做完了的i行,其状态为s,的方案数. 两个状态之间是否可以转移就留 ... 
- 【NOIP2016提高A组模拟9.17】小a的强迫症
		题目 分析 题目要求第i种颜色的最后一个珠子要在第i+1种颜色的最后一个珠子之前, 那么我们从小到大枚举做到第i种,把第i种的最后一颗珠子取出,将剩下的\(num(i)-1\)个珠子插入已排好的前i- ... 
- 【NOIP2016提高A组模拟8.17】(雅礼联考day1)总结
		考的还ok,暴力分很多,但有点意外的错误. 第一题找规律的题目,推了好久.100分 第二题dp,没想到. 第三题树状数组.比赛上打了个分段,准备拿60分,因为时间不够,没有对拍,其中有分段的20分莫名 ... 
- 【NOIP2016提高A组模拟8.17】(雅礼联考day1)Binary
		题目 分析 首先每个数对\(2^i\)取模.也就是把每个数的第i位以后删去. 把它们放进树状数组里面. 那么当查询操作, 答案就位于区间\([2^i-x,2^{i-1}-1-x]\)中,直接查询就可以 ... 
- 【NOIP2016提高A组模拟8.17】(雅礼联考day1)Value
		题目 分析 易证,最优的答案一定是按\(w_i\)从小到大放. 我们考虑dp, 先将w从小到大排个序,再设\(f_{i,j}\)表示当前做到第i个物品,已选择了j个物品的最大值.转移就是\[f_{i, ... 
- 【NOIP2016提高A组模拟8.17】(雅礼联考day1)Matrix
		题目 分析 假设,我们从\(F_{i,2}\)出发,那么对\(F_{n,n}\)的贡献就是\(某个系数乘以a^{n-i}b^{n-1}r_i\): 同理,如果从\(F_{2,i}\)出发,那么对\(F ... 
随机推荐
- 16_k近邻算法总结
			1.k近邻算法属于分类算法 2.你的“邻居”来推断出你的类别 3.标准定义:如果一个样本在特征空间中的k个最相似(即特征空间中最邻近)的样本中的大多数属于某一个类别,则该样本也属于这个类别. 4.计算 ... 
- ERP或PLM系统-物料编码管理的技术实现
			1 企业现状 企业日常经营过程中会产生大量的文档,如设计图纸.变更单.计算书.设计方案等,如果是制造企业还会产生大量的产品.组成产品的零部件等物料,这些数据在进入信息系统前都需要有一个唯一的标识,也就 ... 
- 微信小程序——简易动画案例
			wxml: <view class="container"> <view animation="{{animation}}" class=&q ... 
- ACM中Java使用注意事项
			1. String 类用来存储字符串,可以用charAt方法来取出其中某一字节,计数从0开始, 而不是像C/C++那样使用 []访问是每个字符. 2. 在主类中 main 方法必须是 public s ... 
- SDF与MDF的区别
			标签: 杂谈 数据库扩展名为.sdf,是一个基于sql server compact edition的数据库文件,不需要安装SQL Server就可以用 基于服务的数据库扩展名为.mdf,是基于S ... 
- Cesium官方教程5--地形图层
			原文地址:https://cesiumjs.org/tutorials/Terrain-Tutorial/ Cesium支持渐进流式加载和渲染全球高精度地形,并且包含海.湖.河等水面效果.相对2D地图 ... 
- python-基础-练习和面试题
			给程序传参数 import sys print(sys.argv) 运行结果: 列表推导式 所谓的列表推导式,就是指的轻量级循环创建列表 1. 基本的方式 2. 在循环的过程中使用if 3. 2个fo ... 
- 2018-2-13-win10-uwp-设置启动窗口大小--获取窗口大小
			title author date CreateTime categories win10 uwp 设置启动窗口大小 获取窗口大小 lindexi 2018-2-13 17:23:3 +0800 20 ... 
- LOJ 6042 跳蚤王国的宰相
			LOJ 6042 跳蚤王国的宰相 题意 跳蚤王国爆发了一场动乱,国王在镇压动乱的同时,需要在跳蚤国地方钦定一个人来做宰相. 由于当时形势的复杂性,很多跳蚤都并不想去做一个傀儡宰相,带着宰相的帽子,最后 ... 
- mysqldump mysql数据库导出命令
			mysqldump -u用户名 -p密码 数据库名 > 导出的文件名 例如: mysqldump -uroot -p123456 test > /var/test.sql 如果要压缩就用管 ... 
