Chino的成绩

题目描述

Chino非常注重自己的成绩

Chino有m种方式给自己增加rp以增加成绩,她的每种增加rp的方式都有n个阶段,第i种的第j个阶段增加的rp表示为Aij​,表示连续进行了j天第i种增加rp的方式

Chino连续进行同一种方式,效果可能更好也可能更差,她想要知道在n天里能获得的最大rp,你能帮帮可爱的Chino吗?

输入输出格式

输入格式:

第一行,两个正整数n,m

接下来m行,第i+1行为n个整数A[i][1]~A[i][n]​

输出格式:

一行一个数,最大的rp

输入输出样例

输入样例#1:

3 3
3 2 1
3 1 1
3 3 1
输出样例#1:

9
输入样例#2:

3 3
3 2 1
3 5 2
4 1 1
输出样例#2:

12

说明

本题分为3个Subtask

第一个Subtask,2组数据 ,保证n \leq 50n≤50, m \leq 5000m≤5000, a_i \leq 1e9ai​≤1e9

对于第二个Subtask,4组数据,保证n \leq 70n≤70, m \leq 10000m≤10000, a_i \leq 1e9ai​≤1e9

对于第三个Subtask,4组数据,保证n \leq 100n≤100, m \leq 5000m≤5000, a_i \leq 1e9ai​≤1e9

其中每组数据4分,对于每个Subtask及其中的每个数据点,取分数和。

样例解释1

第 1 天进行第 1 项活动,获得 A11​=3 点rp。

第 2 天进行第 2 项活动,获得 A21​=3 点rp。

第 3 天进行第 1 项活动,获得 A11​=3 点rp。

样例解释2

第 1 天进行第 2 项活动,获得 A21​=3 点rp。

第 2 天进行第 2 项活动,获得 A22​=5 点rp(因为已经连续进行了 2 次第 2 项活动,因而是 A22​ 而不是 A21​。

第 3 天进行第 3 项活动,获得 A31​=4 点rp。

这个坑留了好久吧,终于回来填坑了

sol:

首先如果a = {3, 2, 1}, 如果取三天只能是6, 9是不合法的,这个要搞清楚

所以当前这个方案取了几天一定要有

f(i, j)表示到第i天,以第j中方案结尾的最大rp

g(i, j)记录当前这个方案取了几天

1、继续采用当前的方案
f(i,j)=f(i−1,j)+a[j][g(i−1,j)+1])
g(i,j)=g(i−1,j)+1
2、更换方案
f(i,j)=max(f(i−1,k)+a[j][1])(k!=j)
g(i,j)=1

然后这个k可以用前缀和处理掉,(滚存一下)

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int n, m, a[][];
int f[][], g[][];
int pre[], suf[];
int main()
{
scanf("%d%d", &n, &m);
for(int i = ; i <= m; i++)
for(int j = ; j <= n; j++)
scanf("%d", &a[i][j]);
memset(f, , sizeof f);
memset(g, , sizeof g);
for(int i = ; i <= n; i++)
{
for(int j = ; j <= m; j++)
{
if (f[i - ][j] + a[j][g[i - ][j] + ] > max(pre[j - ], suf[j + ]) + a[j][])
{
f[i][j] = f[i - ][j] + a[j][g[i - ][j] + ];
g[i][j] = g[i - ][j] + ;
}
else
{
f[i][j] = max(pre[j - ], suf[j + ]) + a[j][];
g[i][j] = ;
}
}
memset(pre, , sizeof pre);
memset(suf, , sizeof suf);
for(int j = ; j <= m; j++)
pre[j] = max(pre[j - ], f[i][j]);
for(int j = m; j >= ; j--)
suf[j] = max(suf[j + ], f[i][j]);
}
int ans = ;
for(int i = ; i <= m; i++)
ans = max(ans, f[n][i]);
printf("%d\n", ans);
}

luogu T40984Chino的成绩的更多相关文章

  1. 「Luogu 2367」语文成绩

    更好的阅读体验 Portal Portal1: Luogu Description 语文老师总是写错成绩,所以当她修改成绩的时候,总是累得不行.她总是要一遍遍地给某些同学增加分数,又要注意最低分是多少 ...

  2. CJOJ 1331 【HNOI2011】数学作业 / Luogu 3216 【HNOI2011】数学作业 / HYSBZ 2326 数学作业(递推,矩阵)

    CJOJ 1331 [HNOI2011]数学作业 / Luogu 3216 [HNOI2011]数学作业 / HYSBZ 2326 数学作业(递推,矩阵) Description 小 C 数学成绩优异 ...

  3. Luogu 1068 - 分数线划定 - [快速排序]

    题目链接:https://www.luogu.org/problemnew/show/P1068 题目描述世博会志愿者的选拔工作正在 A 市如火如荼的进行.为了选拔最合适的人才,A 市对所有报名的选手 ...

  4. Luogu 1093 - 奖学金 - [排序水题]

    题目链接:https://www.luogu.org/problemnew/show/P1093 题目描述某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前5名学生发奖学金.期末,每个学生 ...

  5. [JLOI 2016]成绩比较

    Description 题库链接( \(\text{bzoj}\) 不知道为什么过不了啊... \(\text{luogu loj}\) 都能过...就给 \(\text{luogu}\) 的链接了. ...

  6. [luogu P3216] [HNOI2011]数学作业

    [luogu P3216] [HNOI2011]数学作业 题目描述 小 C 数学成绩优异,于是老师给小 C 留了一道非常难的数学作业题: 给定正整数 N 和 M,要求计算 Concatenate (1 ...

  7. hyfhaha大事记——luogu

    成就墙 AK CSP-J 初赛 AK CSP-J 复赛 CSP- J 一等奖 CSP-S 一等奖 大事记 2017-09-20 13:54 注册洛谷账号 之后洛谷一直处于沉沦状态 2018 2018- ...

  8. sql面试题(学生表_课程表_成绩表_教师表)

    原帖链接:http://bbs.csdn.net/topics/280002741 表架构 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程 ...

  9. 2016福州大学软件工程Beta阶段团队作业成绩汇总

    1.评分规则 本次Beta阶段团队作业评分方法如下: 团队得分=[[7次scrum过程评分+(小组互评得分+教师评分)/2]/2],其中过程.小组.教师各30分 说明:由于没有规定提交团队贡献比,因此 ...

随机推荐

  1. HyperLedger Fabric 1.0的Transaction处理流程

    如果把区块链比作一个只能读写,不能删改的分布式数据库的话,那么事务和查询就是对这个数据库进行的最重要的操作.以比特币来说,我们通过钱包或者Blockchain.info进行区块链的查询操作,而转账行为 ...

  2. 常用的移动前端webapp交互细节

    #常用的移动前端webapp交互细节 ##select的表现方式 ###PC端 select控件在传统PC桌面已经存在多年,由于在IE6等低版本浏览器容易造成层级错乱,一直被一些UI框架所抛弃,而用d ...

  3. MySQL的log_bin和sql_log_bin 的区别

    利用二进制还原数据库的时候,突然有点纠结,log_bin和sql_log_bin有什么区别呢?行吧,搜搜,结合自己的经验,简单说一下.log_bin:二进制日志. 在 mysql 启动时,通过命令行或 ...

  4. Python—闭包

    闭包的定义:即函数定义和函数表达式位于另一个函数的函数体内(嵌套函数).而且,这些内部函数可以访问它们所在的外部函数中声明的所有局部变量.参数.当其中一个这样的内部函数在包含它们的外部函数之外被调用时 ...

  5. poj 1486 纸张与数字匹配(二分图+割边处理)

    题目来源:http://poj.org/problem?id=1486 题意: 算出所有独一无二的字母与数字的组合,使二分图完全匹配 我以为所有点都要独一无二匹配时输出匹配方法 题解: 先得到一个完全 ...

  6. C#跨进程读取listview控件中的数据

    http://www.cnblogs.com/Charltsing/p/slv32.html 欢迎交流:QQ564955427 读取标准的32位listview控件中的数据,网上已经有很多代码了.今天 ...

  7. python的循环和选择

    一.python的选择结构: python的选择结构有两种选择结构一种是单选择(if...else)另一种则是多选择结构(if ...elif...elif) 下面用代码来实现: 1.if....el ...

  8. 使用队列queue实现一个简单的生产者消费者模型

    一.生产者消费者模型 我们去超市商店等地购买商品时,我们大部分人都会说自己是消费者,而超市的各大供货商.工厂等,自然而然地也就成了我们的生产者.如此一来,生产者有了,消费者也有了,那么将二者联系起来的 ...

  9. BOM、DOM

    window对象 所有浏览器都支持window对象,他表示浏览器窗口. 全局变量是window对象的属性.全局函数是window对象的方法. window的常用方法: window.innerHeig ...

  10. SOAP UI-----测webservice接口

    webservice的请求报文和返回报文都是xml格式的. 使用soapui.storm对webservice接口进行测试,postman无法测. http://www.webxml.com.cn/W ...