NOIP2007 矩阵取数游戏
题目描述
帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的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 矩阵取数游戏的更多相关文章
- NOIP2007 矩阵取数游戏(区间DP)
传送门 这道题第一眼看上去可能让人以为是贪心……不过贪心并不行,因为每次的操作是有2的幂次方的权值的.这样的话直接每次贪心最小的就目光短浅.所以那我们自然想到了DP. 据说这是一道很正常的区间DP? ...
- [P1005][NOIP2007] 矩阵取数游戏 (DP+高精)
我不会高精…… 也不会DP…… 这道题即考高精又考DP…… 我要死了 给一个不是高精的代码(当然不能满分) #include<cstdio> #include<iostream> ...
- [NOIP2007] 提高组 洛谷P1005 矩阵取数游戏
题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...
- 洛谷1005 【NOIP2007】矩阵取数游戏
问题描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...
- 矩阵取数游戏 NOIP 2007
2016-05-31 17:26:45 题目链接: NOIP 2007 矩阵取数游戏(Codevs) 题目大意: 给定一个矩阵,每次在每一行的行首或者行尾取一个数乘上2^次数,求取完最多获得的分数 解 ...
- NOIP2007矩阵取数[DP|高精度]
题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...
- 1166 矩阵取数游戏[区间dp+高精度]
1166 矩阵取数游戏 2007年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description [ ...
- 洛谷 P1005 矩阵取数游戏
题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...
- codevs1166 矩阵取数游戏
题目描述 Description [问题描述] 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m 的矩阵,矩阵中的每个元素aij均 为非负整数.游戏规则如下: 1. 每次取数时须从每行各取走一个 ...
随机推荐
- 代理模式(Proxy Pattern)
一.引言 在软件开发过程中,有些对象有时候会由于网络或其他的障碍,以至于不能够或者不能直接访问到这些对象,如果直接访问对象给系统带来不必要的复杂性,这时候可以在客户端和目标对象之间增加一层中间层,让代 ...
- 继续OI
NOIP2016于2016.11.20日12:00正式结束. 我作为oi的生涯 或许会结束? 或者继续? 然而前途依然迷茫,我是否应该继?或是放弃? 距离省选还有3~4个月,我该何去何从? 虽然已经经 ...
- 2016HUAS_ACM暑假集训4M - 基础DP
简单的0-1背包问题,大家都会做的.题意不想解释太多. 简述题目的案例及以几个关键 Sample Input 1 //测试组数T 5 10 ...
- js中cookie的使用详细分析
JavaScript中的另一个机制:cookie,则可以达到真正全局变量的要求. cookie是浏览器 提供的一种机制,它将document 对象的cookie属性提供给JavaScript.可以由J ...
- Timberwolves forward Kevin Garnett to retire _洛杉矶时报
Timerwolves:森林狼队,forward:前锋; kevin Garnett,the best player in Minnesota Timberwolves history,is expe ...
- Android单元测试实践
为什么要写单元测试 首先要介绍为什么蘑菇街支付金融这边会采用单元测试的实践.说起来比较巧,刚开始的时候,只是我一个人会写单元测试.后来老板们知道了,觉得这是件 很有价值的事情,于是就叫我负责我们组的单 ...
- Java-适配器
对于Java程序来说,如果一个类要实现一个接口,则必须要覆写此接口中的全部抽象方法,那么如果此时一个接口中定义了抽象方法过多,但是在子类中有用不到这么多的抽象方法,则肯定很麻烦,所以此时需要一个中间的 ...
- Lua学习----Lua基础数据类型
前言 Lua有6中数据类型,分别是nil(空).boolean(布尔).number(数字).string(字符).table(表).function(函数) 在Lua中可以使用type函数来返回一个 ...
- tokudb引擎磁盘空间不足导致写入失败的调查
故障现象 2016.1.1号早上4点左右,zabbi数据库服务器报警,写入数据失败.登陆机器后检查发现磁盘空间使用95%没有用满,进去zabbix数据库,执行insert命令提示错误“errir 10 ...
- 黄聪:微信支付错误两个问题的解决:curl出错,错误码:60
如下是运行微信支付测试代码时出错代码: Warning: curl_setopt() expects parameter 2 to be long, string given in D:\wwwroo ...