noip 2009 道路游戏
/*10分钟的暴力 意料之中的5分..*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 1010
using namespace std;
int n,m,p,g[maxn][maxn],w[maxn],ans;
void Dfs(int now,int v)
{
if(now>m){ans=max(ans,v);return;}
for(int i=;i<=n;i++)
for(int j=;j<=p;j++)
{
int vi=;
for(int k=i,r=;r<=j;r++,k++)
vi+=g[k%(n+)][r+now];
Dfs(now+j,v+vi-w[i]);
}
}
int main()
{
scanf("%d%d%d",&n,&m,&p);
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
scanf("%d",&g[i][j]);
for(int i=;i<=n;i++)
scanf("%d",&w[i]);
for(int i=;i<=n;i++)
for(int j=;j<=p;j++)
{
int vi=;
for(int k=i,r=;r<=j;r++,k++)
vi+=g[k%(n+)][r];
Dfs(j,vi-w[i]);
}
printf("%d\n",ans);
return ;
}
/*
考场上写的未优化的dp O(n^4) 40分
f[i][j]表示第i分钟 在j位置的最大收益
转移的话 枚举上一次选机器人走了几步
同时可以算出上次的起点 也就有了上个状态到现在的收益
这是考场上写的dp 后来发现有点小问题就是算上次的起点比较麻烦
后来直接不存起点这个状态
f[i]表示第i分钟的最大收益
同样的我们枚举上一次规定机器人走了几步
与此同时我们枚举j 表示上次的起点是谁
这样是j+枚举的步数 巧妙的避开了比较复杂的处理
然后计算收益 实现转移
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 1010
using namespace std;
int n,m,p,g[maxn][maxn],w[maxn],f[maxn];
int main()
{
//freopen("roadgame.in","r",stdin);
//freopen("roadgame.out","w",stdout);
scanf("%d%d%d",&n,&m,&p);
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
scanf("%d",&g[i][j]);
for(int i=;i<=n;i++)
scanf("%d",&w[i]);
memset(f,,sizeof(f));f[]=;
for(int i=;i<=m;i++)
for(int j=;j<=n;j++)
for(int k=;k<=p;k++)
{
if(i-k<)continue;int vi=;
for(int l=i-k+,r=j;l<=i;l++,r++)vi+=g[r][l],r%=n;
f[i]=max(f[i],f[i-k]-w[j]+vi);
}
printf("%d\n",f[m]);
return ;
}
/*
后来看别人博客上的优化 恍然大悟!
上面的tle的dp很明显慢在计算收益上
然而收益与时间有关系 又不能用差分预处理(后来想想好像也可以 但比较麻烦)
我们枚举k 表示上次选的走几步时 每次的一次相加的
这里可以优化掉他 直接维护总的
因为枚举k的顺序决定了这里j枚举这次得起点会比较简单
这样随着枚举k可以依次算出vi
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 1010
using namespace std;
int n,m,p,g[maxn][maxn],w[maxn],f[maxn];
int main()
{
//freopen("roadgame.in","r",stdin);
//freopen("roadgame.out","w",stdout);
scanf("%d%d%d",&n,&m,&p);
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
scanf("%d",&g[i][j]);
for(int i=;i<=n;i++)
scanf("%d",&w[i]);
memset(f,,sizeof(f));f[]=;
for(int i=;i<=m;i++)
for(int j=;j<=n;j++)//这次的出发点
{
int r=j-,vi=;//vi 表示累计的收益
if(r==)r=n;vi+=g[r][i];
for(int k=;k<=p;k++)
{
if(i-k<)continue;
f[i]=max(f[i],f[i-k]-w[r]+vi);
if(r==)r=n;else r--;
vi+=g[r][i-k];//只需要O(1)计算
}
}
printf("%d\n",f[m]);
return ;
}
noip 2009 道路游戏的更多相关文章
- NOIP2009pj道路游戏[环形DP 转移优化 二维信息]
题目描述 小新正在玩一个简单的电脑游戏. 游戏中有一条环形马路,马路上有 n 个机器人工厂,两个相邻机器人工厂之间由一小段马路连接.小新以某个机器人工厂为起点,按顺时针顺序依次将这 n 个机器人工厂编 ...
- 洛谷 P1070 道路游戏 解题报告
P1070 道路游戏 题目描述 小新正在玩一个简单的电脑游戏. 游戏中有一条环形马路,马路上有\(n\)个机器人工厂,两个相邻机器人工厂之间由一小段马路连接.小新以某个机器人工厂为起点,按顺时针顺序依 ...
- 洛谷P1070 道路游戏
P1070 道路游戏 题目描述 小新正在玩一个简单的电脑游戏. 游戏中有一条环形马路,马路上有 n 个机器人工厂,两个相邻机器人工厂之间由一小段马路连接.小新以某个机器人工厂为起点,按顺时针顺序依次将 ...
- [luogu]P1070 道路游戏[DP]
[luogu]P1070 道路游戏 题目描述小新正在玩一个简单的电脑游戏.游戏中有一条环形马路,马路上有 n 个机器人工厂,两个相邻机器人工厂之间由一小段马路连接.小新以某个机器人工厂为起点,按顺时针 ...
- 最优贸易 NOIP 2009 提高组 第三题
题目描述 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个 城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分 为双向通行的道路 ...
- 道路游戏(洛谷 P1070)
题目描述 小新正在玩一个简单的电脑游戏. 游戏中有一条环形马路,马路上有 n 个机器人工厂,两个相邻机器人工厂之间由一小段马路连接.小新以某个机器人工厂为起点,按顺时针顺序依次将这 n 个机器人工厂编 ...
- NOIP 2009 潜伏者
P1071 潜伏者 题目描述 RR 国和 SS 国正陷入战火之中,双方都互派间谍,潜入对方内部,伺机行动.历尽艰险后,潜伏于 SS 国的 RR 国间谍小 CC 终于摸清了 SS 国军用密码的编码规则: ...
- 洛谷 P1070 道路游戏 DP
P1070 道路游戏 题意: 有一个环,环上有n个工厂,每个工厂可以生产价格为x的零钱收割机器人,每个机器人在购买后可以沿着环最多走p条边,一秒走一条,每条边不同时间上出现的金币是不同的,问如何安排购 ...
- 洛谷P1067 多项式输出 NOIP 2009 普及组 第一题
洛谷P1067 多项式输出 NOIP 2009 普及组 第一题 题目描述 一元n次多项式可用如下的表达式表示: 输入输出格式 输入格式 输入共有 2 行 第一行 1 个整数,n,表示一元多项式的次数. ...
随机推荐
- DOS命令行中用MAVEN构建 Java 和 Java Web 项目
一.Maven的安装 : 1.将 maven3.0解压到任一目录下,如D:\Program Files 2.配置环境变量:变量名: MAVEN_HOME 变量值:D:\Program Files\ ...
- 交叉编译:cannot find /lib/libc.so.6 collect2: ld returned 1 exit status
1.有时候明明指定了交叉编译的动态库搜索路径,但有些库提示还是搜索不到,而且提示的搜索路径有点奇怪,不是指定的路径,比如: /opt/mips-4.4/bin/../lib/gcc/mips-linu ...
- (转载)小课堂UI-有关配色的一个小技巧
- nuc900 nand flash mtd 驱动
nuc900 nand flash mtd 驱动,请参考! /* * Copyright © 2009 Nuvoton technology corporation. * * Wan ZongShun ...
- php设计模式之简单工厂模式
①抽象基类:类中定义抽象一些方法,用以在子类中实现 ②继承自抽象基类的子类:实现基类中的抽象方法 ③工厂类:用以实例化所有相对应的子类 /** * * 定义个抽象的类,让子类去继承实现它 * */ a ...
- matlab图像类型转换以及uint8、double、im2double、im2uint8和mat2gray等说明
转自:http://blog.csdn.net/fx677588/article/details/53301740 1. matlab图像保存说明 matlab中读取图片后保存的数据是uint8类型( ...
- struts2整合spring出现的Unable to instantiate Action异常
在struts2整合spring的时候,完全一步步按照官方文档上去做的,最后发现出现 Unable to instantiate Action,网上一搜发现很多人和我一样的问题,配置什么都没有错误,就 ...
- 打印机PCL漏洞原理分析
0x01 漏洞概要 PCL代表打印机控制语言(Printer Control Language),由惠普公司开发,并被广泛使用的一种打印机协议.关于另一种页面描述语言,应该提一提由Adobe设计的Po ...
- EGE图形库配置(Dev-C++ 5.10 , TDM GCC 4.8.1)
准备工作:1>Dev-C++ 5.10版本 系统 Win XP/WIN 7 2>下载EGE图形库“ege-13.04.02-full” !,关于本次配置的Dev-C++的信息见如: ...
- IOS笔记 1
< ![CDATA[ 笔记 UIWindows 与UIView的关系iOS的坐标系统视图层次结构视图坐标(Frame和Bounds区别)UIView的常用属性和方法坐标系统的变换UIView内容 ...