题目描述

帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数。游戏规则如下:

1.每次取数时须从每行各取走一个元素,共n个。m次后取完矩阵所有元素;

2.每次取走的各个元素只能是该元素所在行的行首或行尾;

3.每次取数都有一个得分值,为每行取数的得分之和,每行取数的得分 = 被取走的元素值*2^i,其中i表示第i次取数(从1开始编号);

4.游戏结束总得分为m次取数得分之和。

帅帅想请你帮忙写一个程序,对于任意矩阵,可以求出取数后的最大得分。

输入输出格式

输入格式:

输入文件game.in包括n+1行:

第1行为两个用空格隔开的整数n和m。

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

数据范围:

60%的数据满足:1<=n, m<=30,答案不超过10^16

100%的数据满足:1<=n, m<=80,0<=aij<=1000

输出格式:

输出文件game.out仅包含1行,为一个整数,即输入矩阵取数后的最大得分。

这是世界上最丑的高精...然而并不能阻止我AC...

 #include<iostream>
 #include<cstdio>
 #include<cstring>
 #define LL long long
 #define M(x) memset(x,0,sizeof(x))
 using namespace std;
 void ADD(int a[],int b[],int c[]){
     ],b[]);
     ;i<=len;i++){
         c[i]+=a[i]+b[i];
         ){
             c[i+]+=c[i]/;
             c[i]%=;
         }
     }
     ]) c[]=len+;
     ]=len;
 }
 bool BIGGER(int a[],int b[]){
     ]==b[]){
         ];i>=;i--) if(a[i]!=b[i]) return a[i]>b[i];
     }]>b[];
 }
 void C(int a[],int b[],int c[]){
     ;i<=a[];i++){
         ;j<=b[];j++){
             c[i+j-]+=a[i]*b[j];
         }
     }
     c[]=a[]+b[]+;
     ;i<=c[];i++){
         c[i+]+=c[i]/;
         c[i]%=;
     }
     ]]&&c[]>) c[]--;
     return;
 }
 void change(int a,int b[]){
     ){
         b[++b[]]=a%;
         a/=;
     }b[++b[]]=a;
 }
 void print(int a[]){
     ];i>=;i--) printf("%d",a[i]);
 }
 ],v[][],mem[][][],ppow[][];
 void dp(int l,int r,int c[]){
     if(v[l][r]){
         ;i<=mem[l][r][];i++) c[i]=mem[l][r][i];
         return;
     }
     v[l][r]=;
     memset(mem[l][r],,sizeof(mem[l][r]));
     if(l==r){
         ];M(t);
         change(data[l],mem[l][r]);
         C(mem[l][r],ppow[m],t);
         ;i<=t[];i++) mem[l][r][i]=c[i]=t[i];
         return;
     }
     ],t3[],t4[],ll[],rr[];
     M(t2);dp(l+,r,t2);
     M(t3);change(data[l],t3);
     M(t4);C(t3,ppow[m-r+l],t4);
     M(ll);ADD(t2,t4,ll);
     M(t2);dp(l,r-,t2);
     M(t3);change(data[r],t3);
     M(t4);C(t3,ppow[m-r+l],t4);
     M(rr);ADD(t2,t4,rr);
     if(BIGGER(ll,rr)){
         ;i<=ll[];i++) c[i]=mem[l][r][i]=ll[i];
     };i<=rr[];i++) c[i]=mem[l][r][i]=rr[i];
     return;
 }
 void calcppow(){
     M(ppow);
     ppow[][]=;ppow[][]=;
     ];two[]=;two[]=;
     ;i<=;i++) C(ppow[i-],two,ppow[i]);
 }
 int main()
 {
     calcppow();
     ],t[],t2[];memset(ans,,sizeof(ans));
     scanf("%d%d",&n,&m);
     ;i<=n;i++){
         ;j<=m;j++){
             scanf("%d",&data[j]);
         }
         memset(t,,sizeof(t));
         memset(v,,sizeof(v));
         M(mem);
         dp(,m,t);
         M(t2);ADD(ans,t,t2);
         ;i<=t2[];i++) ans[i]=t2[i];
     }
     print(ans);
     ;
 }

NOIP2007 矩阵取数游戏的更多相关文章

  1. NOIP2007 矩阵取数游戏(区间DP)

    传送门 这道题第一眼看上去可能让人以为是贪心……不过贪心并不行,因为每次的操作是有2的幂次方的权值的.这样的话直接每次贪心最小的就目光短浅.所以那我们自然想到了DP. 据说这是一道很正常的区间DP? ...

  2. [P1005][NOIP2007] 矩阵取数游戏 (DP+高精)

    我不会高精…… 也不会DP…… 这道题即考高精又考DP…… 我要死了 给一个不是高精的代码(当然不能满分) #include<cstdio> #include<iostream> ...

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

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

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

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

  5. 矩阵取数游戏 NOIP 2007

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

  6. NOIP2007矩阵取数[DP|高精度]

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

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

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

  8. 洛谷 P1005 矩阵取数游戏

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

  9. codevs1166 矩阵取数游戏

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

随机推荐

  1. Eclipse

    001.自动注释  window--preferences--java--codeStyle--codeTemplate--comments //Types: /** *@author ${user} ...

  2. 浏览器与web客户端的HTTP交互过程

    未经许可谢绝以任何形式对本文内容进行转载! HTTP协议是常见的几种应用层协议之一,当我们用浏览器和web客户端进行交互时html页面等内容的传输都是依靠该协议完成的.值得注意的是,HTTP使用的是T ...

  3. 【Linux命令】之fc,手动安装字体

    在linux,把字体文件拷贝到字体目录后,执行fc-cache命令,fc-cache扫描字体目录并生成字体信息的缓存,然后应用程序就可以立即使用这些新安装的字体. 1.把windows OS下的字体C ...

  4. Ajax在html页面获取后台XML文件资源

    一.准备工具 站长吧ASP调试工具.exe,这个工具是为了快速建立asp环境,方便调试. 二.建立文件夹 1.建立网站根文件夹,名字随意,将站长吧ASP调试工具.exe复制到根文件夹: 2.建立xml ...

  5. JS中正则匹配的三个方法match exec test的用法

    javascript中正则匹配有3个方法,match,exec,test: match是字符串的一个方法,接收一个RegExp对象做为参数: match() 方法可在字符串内检索指定的值,或找到一个或 ...

  6. 如何搭建 node,react 开发环境

    项目相关内容:Sublime + Node + React --注意:在 windows 操作系统中,如果把 node 安装在系统盘(一般是C盘),会导致 node 没有操作文件的权限的问题,如无法新 ...

  7. 数迹学——Asp.Net MVC4入门指南(5):从控制器访问数据模型

    MovieController中的方法Index()代码,初认识,应该有很多理解错误的地方,暂时这么记忆吧,待随后修改 Index()代码: @model IEnumerable<MVCMovi ...

  8. 使用zfs进行pg的pitr恢复测试

    前段时间做了一下zfs做pg的增量恢复测试,mark一下. 服务器信息: 主机:192.168.173.43 备机:192.168.173.41 主备使用流复制搭建,在备机上面进行了zfs快照备份. ...

  9. getview不执行

    <FrameLayout android:layout_width="match_parent" android:layout_height="match_pare ...

  10. cuda-convnet windows8下编译

    编译环境: windows8.1 Anaconda python2.7 Visual studio 2012 CUDA6.0 Pthread for windows Intel Math Kernel ...