来源:牛客网:

文章目录

  • 题目描述
  • 题解:
  • 代码:
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld

题目描述

帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数。游戏规则如下:
1.每次取数时须从每行各取走一个元素,共n个。m次后取完矩阵所有元素;
2.每次取走的各个元素只能是该元素所在行的行首或行尾;
3.每次取数都有一个得分值,为每行取数的得分之和,每行取数的得分 = 被取走的元素值 * 2i,其中i表示第i次取数(从1开始编号);
4.游戏结束总得分为m次取数得分之和。 帅帅想请你帮忙写一个程序,对于任意矩阵,可以求出取数后的最大得分。

输入描述:

第1行为两个用空格隔开的整数n和m。 第2~n+1行为n*m矩阵,其中每行有m个用单个空格隔开的非负整数。

输出描述:

输出一个整数,即输入矩阵取数后的最大得分。

示例1
输入
复制

2 3
1 2 3
3 4 2

输出
复制

82

说明
第1次:第1行取行首元素,第2行取行尾元素,本次得分为1 * 21 + 2 * 21 = 6
第2次:两行均取行首元素,本次得分为2 * 22 + 3 * 22 = 20
第3次:得分为3 * 23 + 4 * 23 = 56。
总得分为6 + 20 + 56 = 82
示例2
输入
复制

1 4
4 5 0 5

输出
复制

122

示例3
输入
复制

2 10
96 56 54 46 86 12 23 88 80 43
16 95 18 29 30 53 88 83 64 67

输出
复制

316994

备注:
60%的数据满足:1 ≤ n, m ≤ 30, 答案不超过1016
100%的数据满足:1 ≤ n, m ≤ 80, 0 ≤ aij ≤ 1000

题解:

每一行都进行的相同操作,且每一行的操作都互不影响,所以我们可以一行一行的考虑,算出每一行的最佳情况然后求和
这样就降低难度维度
先看第一行,只能在行首行尾取,如果我们要知道区间[1,m]的最佳情况,就要知道[1,m-1]和[2,n]的最优解,因为是由他俩推过去的,依次类推
dp[i][j]表示i到j区间的最优解
dp[i][j]=min(dp[i+1][j]+2k *a[i] ,dp[i][j-1] +2k *a[j])
由内向外扩展的过程
区间长度为n时k取1,长度每缩短一次k++,(相当于第k次取)

因为我们乘以2是依次增多的,所以每次都乘以2
本题是需要高精度的,当然也可以使用__int128 +快读快输 (黑魔法)

代码:

#include<bits/stdc++.h>
using namespace std;
#define  _t __int128
inline _t read()
{_t x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=1;ch=getchar();}while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}return x*f;
}
inline void put(_t x)
{if(x<0){putchar('-');x=-x;}if(x>9)put(x/10);putchar(x%10+'0');
}
_t n,m,res;
_t a[103][103],dp[103][104];
_t cul(_t b[])
{for(_t len=1;len<=m;len++){for(_t l=1,r=l+len-1;r<=m;l++,r=l+len-1){dp[l][r]=max(dp[l+1][r]+b[l],dp[l][r-1]+b[r]);dp[l][r]=2*dp[l][r];}} return dp[1][m];
}
int main()
{n=read(),m=read();for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)a[i][j]=read();for(int i=1;i<=n;i++){memset(dp,0,sizeof(dp));res+=cul(a[i]);}put(res);return 0;
}

【每日一题】7月10日精讲—矩阵取数游戏相关推荐

  1. 【每日一题】7月3日精讲—毒瘤xor

    [每日一题]7月3日精讲-毒瘤xor 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536K Special Judge, 64bit IO Format: ...

  2. 【每日DP】day 10、P1005 矩阵取数游戏【区间DP+高精(python)】难度⭐⭐⭐★

    P1005 矩阵取数游戏 输入 2 3 1 2 3 3 4 2 输出 82 说明/提示 NOIP 2007 提高第三题. 数据范围: 60%60\%60% 的数据满足:1≤n,m≤301\le n,m ...

  3. 【区间DP+高精】codevs1166 矩阵取数游戏题解

    转自: [ametake版权所有]http://blog.csdn.net/ametake欢迎来看 http://blog.csdn.net/ametake/article/details/47664 ...

  4. 【日常学习】【区间DP+高精】codevs1166 矩阵取数游戏题解

    题目来自NOIP2007TG3 如果在考场上我现在已经歇菜了吧 今天一整天的时间全部投在这道题上,收获不小. 先上题目 题目描述 Description [问题描述] 帅帅经常跟同学玩一个矩阵取数游戏 ...

  5. 凹凸世界服务器维护到几点,凹凸世界6月10日版本更新停服维护公告_凹凸世界6月10日版本更新了什么_玩游戏网...

    在凹凸世界手游中6月10日版本究竟更新了什么呢?更新的内容又有哪些呢?不清楚的话,接下来就让我们一起来看一下吧~! 亲爱的天使: 感谢您对<凹凸世界>手游的关注与支持.为了给各位天使带来更 ...

  6. 第五人格七月三日服务器维护要多久,第五人格微信每日一题7月3日答案是什么_今天有四个人来访过_玩游戏网...

    <第五人格>2021独特时装体验卡礼包 第五人格2021独特时装体验卡礼包怎么获得?礼包中有独特时装体验卡.角色体验卡等奖励,小编这里就分享一下第五人格2021独特时装体验卡礼包领取地址, ...

  7. 牛客网 每日一题 7月23日题目精讲—wpy的请求

    来源:牛客网: 文章目录 wpy的请求 题解: 代码: wpy的请求 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言524288K Special Judge ...

  8. 【每日一题】7月6日精讲—平衡二叉树

    来源:牛客网: 文章目录 题目描述 题解: 代码: 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 1048576K,其他语言2097152K 64bit IO Format: %ll ...

  9. PMP模拟试题每日5题(5月5日)

    摘要:为帮助即将参加PMP®考试的考生快速熟悉PMP®试题.熟练掌握PMP®相关考点知识,本专栏将每日推出5道PMP®模拟试题(包含试题原题和答案解析),快来进行练习吧! 1.你的敏捷团队与一个开发商 ...

最新文章

  1. javascript加载顺序问题(二)
  2. jlink烧写Nor Flash时出错正确解决方法汇总:PC of target system has unexpected value after programming (2011
  3. 苹果过审ipv6问题
  4. SQL优化常用方法41
  5. 分数化小数c语言题目,习题 2-5 分数化小数 (decimal)(C语言版)
  6. a king读后感 love of the_读后感kinglear
  7. lua 求table长度和判断空
  8. linux执行脚本查找ip,linux 查看ip、用户、时间对应执行的命令
  9. LeetCode 803. 打砖块(并查集)
  10. python两个字典合并、相同key值保留_Python两个字典key相同的值组成新字典?
  11. json格式的简单转换
  12. 安卓编译php,编译PHP
  13. Microsoft Research和Windows Azure合作伙伴对数据发现和共享的影响
  14. python能编译成exe文件吗_python编译成exe文件
  15. Hive On Spark搭建报错:Failed to create Spark client for Spark session xx: ..TimeoutException
  16. C++后台开发学习路线(已多人拿下腾讯后台开发)
  17. 狂神Javaweb笔记
  18. Hackathon 实用指南丨快速给 TiDB 新增一个功能
  19. 基于STM32 Cortex-M3内核F103制作的智能小车项目
  20. 北京外企 外服控股:人服国企借道资产重组上市,发 力数字化谋新篇

热门文章

  1. 硕士论文研究「AI预测性取向」:化妆等因素并不影响判断
  2. mysql select 反选_JQuery实现全选、全不选和反选功能
  3. ios把数据传递到另一个页面_iOS 委托 页面之间传递数值
  4. 针对Spring的Spring Retry 我发现了这样一个大家都不知道的技巧!
  5. sql同时向两个表插入数据_SQL入门-数据库和客户端的安装,表的创建和数据插入...
  6. html如何链接sql sever,SQL Server链接服务器
  7. java爬取新浪微博登陆_30行jsoup代码搞定新浪微博登录抓取爬虫
  8. pearson相关系数_Pearson(皮尔逊)相关系数
  9. 数据结构——哈弗曼编码问题
  10. 禁用笔记本键盘_如何禁用/启用笔记本内置键盘?