[JZOJ P1288] [DP]矩阵取数

@kaike

传送门

07年noipT3?

要我写我肯定放弃 嗯没错就是这么果断

据说要 高精 DP 状态?

 

举例说明,假设有矩阵

a1,a2,a3,a4....an

b1,b2,b3,b4....bn

假设矩阵的最大得分取法为

a1*2+b1*2+a2*4+b2*4+a3*8+b3*8+.....+an*2^n+b2*2^n;

可以转换为

a1*2+a2*4+a3*8+...+an*2^n  +  b1*2+b2*4+b3*8+....+bn*2^n;

上面的式子其实也就是a1那一行的最大得分加上b1那一行的最大得分

也就是说 矩阵的最大得分其实是每一行的最大得分之和

每一行的取数不会和其他行发生冲突或联系

于是矩阵取数最大得分就转化为 每一行的最大得分之和

求出每一行的最大得分,求和就可以得到矩阵的最大得分

 

对于每一行都有两种选择,行头和行尾

设f[i][j]表示取i个数,其中j个数为行头,x表示第几行

f[i][j]=max{f[i-1][j-1]+a[x][j]*cifang[i], f[i-1][j]+a[x][m-(i-j)+1]*cifang[i]};

 

 

 1 //第i循环为取第几次数,乘i次方
 2 //第j循环为有几个数是当行头来取得
 3 //易知可取行头和行尾
 4 //第一个式子为取行头,取i-1个数以及j-1为行头+这一个数为行头
 5 //第二个式子为取行尾,取i-1个数以及j为行头,m-(i-j)+1为行尾
 6 
 7 //设第一行为1,2,3,4,5,6,易知m=6,x=1;
 8 //当要取4个数时,i=4,假设前2个数为行头,j=2,这时要取第5个数,5;
 9 // i-1-j 为取得数中行尾的个数  由 m-(i-1-j)可求出要取数的坐标 
10 //也就是 m-(i-j)+1 ;
11 void work(int x)
12 {
13     for(int i=1;i<=m;i++)
14         for(int j=0;j<=i;j++)
15         {
16             f[i][j]=max(f[i][j],f[i-1][j-1]+a[x][j]*ci[i]);
17             f[i][j]=max(f[i][j],f[i-1][j]+a[x][m-(i-j)+1]*ci[i]);
18         }
19 }

 

 

先来一把不是高精的只能得暴力分60的code

 1 #include<iostream>
 2 #include<algorithm>
 3 #include<cstring>
 4 using namespace std;
 5 int n,m,a[100][100];
 6 long long f[100][100],ci[100],ans=0,maxx=-10000;
 7 void init()
 8 {
 9     cin>>n>>m;
10     for(int i=1;i<=n;i++)
11         for(int j=1;j<=m;j++)
12             cin>>a[i][j];
13 }
14 void cifang()
15 {
16     ci[0]=1;
17     for(int i=1;i<=m;i++)
18         ci[i]=ci[i-1]*2;
19 }//预留次方
20 
21 //第i循环为取第几次数,乘i次方
22 //第j循环为有几个数是当行头来取得
23 //易知可取行头和行尾
24 //第一个式子为取行头,取i-1个数以及j-1为行头+这一个数为行头
25 //第二个式子为取行尾,取i-1个数以及j为行头,m-(i-j)+1为行尾
26 
27 //设第一行为1,2,3,4,5,6,易知m=6,x=1;
28 //当要取4个数时,i=4,假设前2个数为行头,j=2,这时要取第5个数,5;
29 // i-1-j 为取得数中行尾的个数  由 m-(i-1-j)可求出要取数的坐标 
30 //也就是 m-(i-j)+1 ;
31 void work(int x)
32 {
33     for(int i=1;i<=m;i++)
34         for(int j=0;j<=i;j++)
35         {
36             f[i][j]=max(f[i][j],f[i-1][j-1]+a[x][j]*ci[i]);
37             f[i][j]=max(f[i][j],f[i-1][j]+a[x][m-(i-j)+1]*ci[i]);
38         }
39 }
40 int main()
41 {
42     init();
43     cifang();
44     for(int i=1;i<=n;i++)
45     {
46         memset(f,0,sizeof(f));
47         maxx=-10000;
48         work(i);
49         for(int j=1;j<=m;j++)
50             maxx=max(maxx,f[m][j]);
51         ans+=maxx;
52     }
53     cout<<ans<<endl;
54     return 0;
55 }
蠢哭了

 

转载于:https://www.cnblogs.com/Kaike/p/5996389.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/469976.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux命令入门

// 查看日历cal // 修改密码passwd // 查看目录和文件ls -lls // 查看当前用户信息whoami // 查看当前在线用户userswho 在Linux中&#xff0c;可以使用 vi 编辑器创建一个文本文件&#xff0c;例如&#xff1a;$ vi filename上面的命令会创建文件 filename 并打开&#xff0c;…

Bug2算法的实现(RobotBASIC环境中仿真)

移动机器人智能的一个重要标志就是自主导航&#xff0c;而实现机器人自主导航有个基本要求——避障。之前简单介绍过Bug避障算法&#xff0c;但仅仅了解大致理论而不亲自动手实现一遍很难有深刻的印象&#xff0c;只能说似懂非懂。我不是天才&#xff0c;不能看几遍就理解理论中…

策略模式场景举例

容错恢复机制 容错恢复机制是应用程序开发中非常常见的功能。那么什么是容错恢复呢&#xff1f;简单点说就是&#xff1a;程序运行的时候&#xff0c;正常情况下应该按照某种方式来做&#xff0c;如果按照某种方式来做发生错误的话&#xff0c;系统并不会崩溃&#xff0…

php写抢票脚本,火车票抢票python代码公开揭秘!

市场上很多火车票抢票软件大家应该非常熟悉&#xff0c;但很少有人研究具体是怎么实现的&#xff0c;所以觉得很神秘&#xff0c;其实很简单。下面使用Python模拟抢票程序&#xff0c;给大家揭秘抢票到底是怎么回事。该代码仅供参考&#xff0c;主要用于大家沟通交流&#xff0…

代理模式——HeadFirst设计模式学习笔记

代理模式&#xff1a;为另一个对象提供一个替身或占位符控制这个对象的访问 特点&#xff1a; 让代理对象控制对象的访问&#xff0c;被代理对象可以是远程对象&#xff08;远程代理&#xff09;&#xff0c;创建开销较大对象&#xff08;虚拟代理&#xff09;&#xff0c;或需…

cursor用法java,Cursor的基本使用方法

Cursor的基本使用方法今天在用到Cursor的时候发现&#xff0c;有很多游标相关的知识还是有欠缺&#xff0c;在网上搜了篇基础讲解的文&#xff0c;觉得还不错&#xff0c;自己整理了一下发上来。虽然很基础&#xff0c;但是有一些内容之前确实没有很扎实得掌握&#xff0c;所以…

win7(64位)php5.5-Apache2.4-mysql5.6环境安装

win7&#xff08;64位&#xff09;安装搭建 php-5.5.10 apache2.4.7 mysql-5.6.16 环境 工具/原料 php-5.5.10-Win32-VC11-x64.zip 下载地址: http://windows.php.net/download/ httpd-2.4.7-win64-VC11.zip 下载地址: http://www.apachelounge.com/download/ mysql-5.6.16-win…

php开发环境 ubuntu,Ubuntu配置PHP开发环境

开发环境安装目前web服务器有很多&#xff0c;本文安装Apache服务器&#xff1b;本文使用的服务器是Mysql服务器。sudo apt install apache2常用命令重启Apache&#xff1a;sudo /etc/init.d/apache2 restart重启php&#xff1a;sudo /etc/init.d/php-fapm restart配置apache服…

php基础知识总结大全,php基础知识回顾 —— 常量

您现在的位置是&#xff1a;网站首页>>PHP>>phpphp基础知识回顾 —— 常量发布时间&#xff1a;2019-01-23 17:23:08作者&#xff1a;wangjian浏览量&#xff1a;489点赞量&#xff1a;0在PHP中有这样一类变量&#xff0c;当变量值被定义之后&#xff0c;它的值就不…

Android Studio 下使用git -- 个人,本地版本控制

第一步&#xff1a;下载安装git 下载地址 : https://git-scm.com/downloads 第二步&#xff1a;Android Studio 下配置git路径。 配置之后&#xff0c;Test弹出如下成功的提示即可。 第三步&#xff1a;创建版本库 选择项目的根目录比较适合。 第四步&#xff1a;添加需要版本控…

oracle忽略除数为0,ora-01476除数为0的解决办法,oracle中decode()的使用

执行报表查询&#xff0c;固定的一个时间点没有数据&#xff0c;应该是有数据的&#xff0c;把前一个时间节点往前调是有的&#xff0c;往后调也有bebug报错把sql放到数据库中&#xff0c;发现提示如截图解决办法&#xff0c;oracle中的decode()select decode(b,0,0,a/b*100) …

Java GridBagLayout 简单使用

这里只介绍了很基础布局构建及使用&#xff0c;主要是关于 GridBagLayout. 首先整套流程大概是&#xff0c; 声明一个 GridBagLayout 对象 private GridBagLayout gridBagLayoutFrame new GridBagLayout(); 然后把当前类的容器布局管理器设置为 GridBagLayout this.setLayout(…

Angular之简单的登录注册

使用Angular实现了一个简单的登录注册的功能........ 涉及到的Angular知识点很少 主要是这个功能的实现...(*^__^*) 嘻嘻…… 里面涉及到的知识点记录: 1.本地存储的操作 localStorage 获取本地存储的值 window.localStorage.getItem(key)-->value (得到的数据是字符串&qu…

微信扫码下载iosAPP

1.首先在应用宝上传你的安卓APP应用&#xff0c;AppStore已经有了APP 2.进入应用宝app应用管理中心&#xff0c;点击“微下载”&#xff0c;然后里面的微下载链接地址就可以用了&#xff0c;可以看到ios可以通过应用宝再跳到AppStore就可以实现下载了转载于:https://www.cnblog…

linux中的加法函数,上下文管理练习(为加法函数计时)

上下文管理(为加法函数计时)为加法函数计时使用装饰器显示该函数的执行时长使用上下文管理显示该函数的执行时长装饰器实现import timeimport datetimefrom functools import wrapsdef logger(fn):wraps(fn) # wraps(fn)(wrapper)def wrapper(*args, **kw):start datetime.dat…

07数组与接口

1、运行TextInherists.java 示例&#xff0c;观察输出&#xff0c;注意总结父类与子类之间构造方法的的调用关系&#xff0c;修改parent构造方法的代码&#xff0c;显式调用grandparent另一个构造函数。 源代码&#xff1a; class GrandParent{ public GrandParent(){ System.o…

windows 访问linux中的mongodb,MongoDB的linux系统下的安装与连接

一 安装MongoDB的服务下载Linux系统下的MongoDB安装包上传压缩包到linux服务器中&#xff0c;解压到对应的安装目录下mkdir /usr/local/mongodbtar -zxvf mongodb-linux-x86_64-4.0.10.tgzmv mongodb-linux-x86_64-4.0.10 /usr/local/mongodb新建目录&#xff0c;分别用来存储数…

linux sqlserver 管理工具,Linux连接SqlServer的图形化工具SQuirrel

SQuirrel SQL一款基于java的数据库管理工具。所以可以运行在任意平台上&#xff0c;除了界面丑一点。在windows上我绝对不会选的&#xff0c;navicat多好。安装下载地址&#xff1a;https://sourceforge.net/projects/squirrel-sql/?sourcetyp_redirect在控制台运行&#xff1…

JDK源码包结构分类

最近查看JDK源码时&#xff0c;无意间发现几个类在陌生包里&#xff1a;com.sun.*、sun.*、org.*&#xff0c;google了一把总结了下以备他人搜索&#xff0c;如内容有误欢迎指正&#xff01;Jre库包含的jar文件(jdk1.6)&#xff1a;resources.jar、rt.jar、jsse.jar、jce.jar、…

GJM :Sql 各种语句 以及函数 [转载]

版权声明&#xff1a;本文原创发表于 【请点击连接前往】 &#xff0c;未经作者同意必须保留此段声明&#xff01;如有侵权请联系我删帖处理&#xff01;1.更改数据库的名称 2.表中有数据的情况下再添加列、删除列 3.在SQLServer 中各种查询语句的使用示例 4.模糊查询的语句 5.…