OJ题号:洛谷1005

思路:

动态规划。

不难发现每行能够取得的最大值仅与当前行的数据有关,因此本题可以对每行的数据分别DP,最后求和。

设$f_{i,j}$表示左边取$i$个、右边取$j$个的最大值,则DP方程为$f_{i,j}=max(f_{i-1,j}+a_{i-1}*2^{i+j},f_{i,j-1}+a_{m-j}*2^{i+j})$。

然而数据规模较大,使用 int 只有40分,用 unsigned long long 只有60分。所以需要高精度,不过实现起来并不复杂。

另外有一些小小的优化,比如压位、预处理二的幂。

 #include<cstdio>
#include<cstring>
#include<algorithm>
class BigInt {
private:
static const int k=;
int num[],len;
public:
BigInt() {
memset(num,,sizeof num);
len=;
}
BigInt(const int len,const int num) {
this->len=len;
this->num[]=num;
}
BigInt operator + (const BigInt &x) const {
BigInt ans;
for(int i=;i<=(ans.len=std::max(this->len,x.len));i++) {
ans.num[i]+=this->num[i]+x.num[i];
ans.num[i+]=ans.num[i]/k;
ans.num[i]%=k;
}
if(ans.num[ans.len+]) ans.len++;
return ans;
}
BigInt operator * (const int &x) const {
BigInt ans;
for(int i=;i<=(ans.len=this->len);i++) {
ans.num[i]+=this->num[i]*x;
ans.num[i+]=ans.num[i]/k;
ans.num[i]%=k;
}
if(ans.num[ans.len+]) ans.len++;
return ans;
}
bool operator < (const BigInt &x) const {
if(this->len<x.len) return true;
if(this->len>x.len) return false;
for(int i=this->len;i>=;i--) {
if(this->num[i]<x.num[i]) return true;
if(this->num[i]>x.num[i]) return false;
}
return false;
}
BigInt& operator = (const BigInt &x) {
this->len=x.len;
std::copy(&x.num[],&x.num[len+],this->num);
return *this;
}
void print() {
printf("%d",num[len]);
for(int i=len-;i>=;i--) {
printf("%04d",num[i]);
}
printf("\n");
}
};
const int M=;
BigInt pow[M]={BigInt(,)};
void calcpow(const int x) {
pow[x]=pow[x-]*;
}
int main() {
int n,m;
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++) calcpow(i);
BigInt ans;
while(n--) {
int a[m];
BigInt f[m+][m+];
for(int i=;i<m;i++) scanf("%d",&a[i]);
memset(f,,sizeof f);
BigInt max;
for(int i=;i<=m;i++) {
for(int j=;j<=m-i;j++) {
if(i) f[i][j]=std::max(f[i][j],f[i-][j]+pow[i+j]*a[i-]);
if(j) f[i][j]=std::max(f[i][j],f[i][j-]+pow[i+j]*a[m-j]);
}
max=std::max(max,f[i][m-i]);
}
ans=ans+max;
}
ans.print();
return ;
}

[NOIp2007提高组]矩阵取数游戏的更多相关文章

  1. [NOIP2007] 提高组 洛谷P1005 矩阵取数游戏

    题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...

  2. 矩阵取数游戏 2007年NOIP全国联赛提高组(dp+高精)

    矩阵取数游戏 2007年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold     题目描述 Description [问题描述]帅帅经常跟 ...

  3. NOIP2007 矩阵取数游戏

    题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...

  4. 洛谷1005 【NOIP2007】矩阵取数游戏

    问题描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...

  5. 1166 矩阵取数游戏[区间dp+高精度]

    1166 矩阵取数游戏 2007年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description [ ...

  6. 矩阵取数游戏 NOIP 2007

    2016-05-31 17:26:45 题目链接: NOIP 2007 矩阵取数游戏(Codevs) 题目大意: 给定一个矩阵,每次在每一行的行首或者行尾取一个数乘上2^次数,求取完最多获得的分数 解 ...

  7. 洛谷 P1005 矩阵取数游戏

    题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...

  8. codevs1166 矩阵取数游戏

    题目描述 Description [问题描述] 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m 的矩阵,矩阵中的每个元素aij均 为非负整数.游戏规则如下: 1. 每次取数时须从每行各取走一个 ...

  9. 矩阵取数游戏洛谷p1005

    题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...

随机推荐

  1. ubuntu 用 apt get 安装某个包的某个版本

    1.首先用如下命令查询你的机器安装了哪些版本: dpkg -l 'apache2*' 2.然后用如下命令查询远程库存在哪些版本: apt-cache madison "libqt5gui5& ...

  2. PHP查看编译参数

    PHP查看编译参数 [root@test ~]# php -i|grep configure Configure Command => './configure' '--prefix=/usr/ ...

  3. ES系列十一、ES的index、store、_source、copy_to和all的区别

    1.基本概念 1.1._source 存储的原始数据._source中的内容就是搜索api返回的内容,如: { "query":{  "term":{   &q ...

  4. angular下载安装

    1.下载安装nodejs 官方地址:https://nodejs.org/en/download/   2.验证是否安装成功 node -v npm -v   公司内网需要设置代理 npm confi ...

  5. spring上传文件

    在使用spring上传文件的时候,使用的文件接收参数类型为 org.springframework.web.multipart.MultipartFile 如果该参数没有指定@RequestParam ...

  6. bert 词典扩充方案

  7. Elasticsearch创建索引和映射结构详解

    前言 这篇文章详细介绍了如何创建索引和某个类型的映射. 下文中[address]指代elasticsearch服务器访问地址(http://localhost:9200). 1       创建索引 ...

  8. poj2114 树分治(点分治)

    poj1741板子套一套,统计对数的方式改一下,可以在O(n)时间内统计对数 最后不要忘记输出最后的“.” /* 给定一棵边权树,是否存在一条路径使得其长度为恰好为x 把1741的板子改为求点对之间的 ...

  9. Yann Martell《少年 pi 的奇幻漂流》

    事情并没有像我们预想的那样发生,你能怎么办呢?无论生活以怎样的方式向你走来,你都应该勇敢地面对它,尽可能地享受它!

  10. div展开与收起(鼠标点击)

    效果图: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...