浅说平面dp(下)

上文链接

最大加权矩形

我们言归正传,首先我们可以想到,这道题其实是要求一个和,那么我们不难想到可以用前缀和来解决,但是这样的时间复杂度过于高了,那么我们怎么办呢?其实我们这里可以用一点最大字段和的知识。

最大字段和

给定一个长为 n 的序列,任意选择其中连续的 x(0≤𝑥≤n)项所确定的一段更短的连续序列叫作一个子段。一个子段的得分为其每个元素之和,请求出原序列的最大子段和。
我们正常来说应该是用枚举的思想,但是这样的时间复杂度为O(n2),如果n稍微大一点就过不了了,那么我们还是考虑动态规划。

首先我们可以想到 d p [ i ] dp[i] dp[i]可能与 d p [ i − 1 ] dp[i-1] dp[i1] a [ i ] a[i] a[i]有关,那么我们就可以想到这个关系式 d p [ i ] = m a x ( d p [ i − 1 ] + a [ i ] , a [ i ] ) dp[i]=max(dp[i-1]+a[i],a[i]) dp[i]=max(dp[i1]+a[i],a[i])
那么我们就可以写出以下代码

#include<bits/stdc++.h>
using namespace std;
long long a[1000000],dp[1000000],n,maxn=0;
int main(){cin>>n;for(int i=1;i<=n;i++){cin>>a[i];dp[i]=0;}for(int i=1;i<=n;i++){dp[i]=max(dp[i-1]+a[i],a[i]);if(dp[i]>maxn){maxn=dp[i];}}cout<<maxn;return 0;
}

这样我们就可以在O(n)的时间复杂度里求完答案

最大子矩阵和和最大字段和的关联

讲了这么多,我们该怎么用呢?
其实我们可以枚举一个上下边界,然后中间就先用前缀和解出中间的值再用最大字段和的方法来解决,这样的时间复杂度就为O(n3),显然可以通过
那么我们就可以得到以下转换代码
d p [ k ] = m a x ( d p [ k − 1 ] + ( t o t [ j ] [ k ] − t o t [ i − 1 ] [ k ] ) , ( t o t [ j ] [ k ] − t o t [ i − 1 ] [ k ] ) ) ; dp[k]=max(dp[k-1]+(tot[j][k]-tot[i-1][k]),(tot[j][k]-tot[i-1][k])); dp[k]=max(dp[k1]+(tot[j][k]tot[i1][k]),(tot[j][k]tot[i1][k]));

那么我们现在就好处理了
代码如下

#include<bits/stdc++.h>
using namespace std;int mp[310][310],tot[310][310];
int dp[310],maxn=INT_MIN;
int main(){int n;cin>>n;for (int i=1;i<=n;i++){for (int j=1;j<=n;j++){cin>>mp[i][j];tot[i][j]=tot[i-1][j]+mp[i][j];}}for (int i=1;i<=n;i++){for (int j=i;j<=n;j++){for (int k=1;k<=n;k++){dp[k]=tot[j][k]-tot[i-1][k];}for (int k=1;k<=n;k++){dp[k]=max(dp[k-1]+(tot[j][k]-tot[i-1][k]),(tot[j][k]-tot[i-1][k]));maxn=max(dp[k],maxn);}}}cout<<maxn;return 0;
}

最大全1子矩阵

给定一个01矩阵,求其最大的全1子矩阵。

第一行n,m。 后面n行每行m个数描述这个矩阵

最大子矩阵的面积

输入数据 1

3 4
1 1 1 1
1 1 1 1 
1 1 1 0

输出数据 1

9

Limitation
对于100%的数据,1<=n,m<=300

思路

这道题其实和上一道题其实差不多还是正常的进行判断,然后在进行dp的时候只需要进行判断,看看是不是都是1就可以了
代码如下

#include<bits/stdc++.h>
using namespace std;int mp[310][310],tot[310][310];
int dp[310],maxn=0;
int main(){int n,m;cin>>n>>m;for (int i=1;i<=n;i++){for (int j=1;j<=m;j++){cin>>mp[i][j];tot[i][j]=tot[i-1][j]+mp[i][j];}}for (int i=0;i<n;i++){//上边界 for (int j=i+1;j<=n;j++){//下边界 memset(dp,0,sizeof(dp));for (int k=1;k<=m;k++){if (tot[j][k]-tot[i][k]==j-i){dp[k]=dp[k-1]+(tot[j][k]-tot[i][k]);maxn=max(maxn,dp[k]);}} }}cout<<maxn;return 0;
}

穿衣服

Description
wjq是一名来自520宿舍的漂亮妹子,她喜欢穿的很性感。 wjq刚刚从床上起来,喜欢性感的她要去她寝室的不同位置去拿衣服,可是她的舍友把她的衣服丢的到处都是,黑丝,白丝,制服等衣服散在不同的位置上,wjq只好挨个去拿。 520宿舍可以看作是一个n行m列的矩形,wjq在(0,0)这个格子(位于宿舍的左上角),寝室的门在(n-1,m-1)这个格子。每次wkc可以向相邻的格子走一步,走到某个格子时,她会穿起这个格子的衣服。wjc由于没有穿鞋,而且用她的粉粉嫩嫩的脚走起来非常的不舒服,然而鞋又在寝室门口,所以她想走一条最短路到教室的门口,但是性感度太少了她自己又不舒服,所以她决定走一条性感程度最高的最短路线(即保证路径最短的前提下性感程度最高),你能帮帮她吗?

Input
第一行三个整数n,m,k。 接下来k行,每行三个整数a,b,c,表示在(a,b)这个格子的衣服的性感程度为c。

Output
输出1个整数,表示wjq的最大性感程度。

Samples
输入数据 1
2 2 2
0 0 1
1 1 1
输出数据 1
2

n,m>=10*9,k>=8000。

思路

如果正常来说,我们肯定使用二维dp来做他,但是可以看到n和m的值非常的大,空间肯定要爆,同时这道题我们又不能用滚动数组来压缩,所以我们只能采取其他的思路

首先我们来想想最短路的问题,不难想到,只要wjq不往左或上走,就一定是最短路。
然后我们再来想想dp的问题,首先我们知道,当前的这一个点只能从这个点的左上方的区域转移而来,那么我们只需要对每一个点进行遍历。然后去找在它左上方的点就可以了。
但是我们又会想到,这样写出来的dp可能有一些值没有被算到,所以我们就需要先对每一个点进行排序,按照从左上方到右下方的顺序来排序。

#include<bits/stdc++.h>
using namespace std;struct f{int x,y;int num;
}a[8000];bool cmp(f a1,f a2){if (a1.y!=a2.y)return a1.y<a2.y;else return a1.x<a2.x;
}
int dp[8000],maxn=INT_MIN;
int main(){int n,m,k;cin>>n>>m>>k;for (int i=1;i<=k;i++){cin>>a[i].x>>a[i].y>>a[i].num;}sort(a+1,a+1+k,cmp);for (int i=1;i<=k;i++){//当前转移的值 dp[i]=a[i].num;for (int j=1;j<=k;j++){if (a[j].x<=a[i].x&&j!=i)dp[i]=max(dp[i],dp[j]+a[i].num);}maxn=max(maxn,dp[i]);}cout<<maxn; return 0;
}

请添加图片描述

请添加图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

SPI通信协议和W25Q64

前言&#xff1a; STM32中的通信接口&#xff1a; UART 单总线 IIC SPI CAN 1. SPI FLASH W25Q64的关系 SPI:一种通信接口&#xff0c;可以用于和搭载SPI接口的设备通信 FLASH:是一种掉电不丢失的存储 -- 手机8256G的256 单片机 64K512K的512 芯片内部flash&…

c语言数据结构--顺序栈

实验内容&#xff1a; 用顺序存储结构&#xff0c;实现教材定义的栈的基本操作&#xff0c;提供数制转换功能&#xff0c;将输入的十进制整数转换成二进制。 实验步骤&#xff1a; &#xff08;1&#xff09;按照实验要求编写代码&#xff0c;构造顺序栈。 &#xff08;2&am…

【密码学】公钥密码的基本概念

在先前我写的密码学体制文章中谈到&#xff0c;现代密码学分为两大体制&#xff0c;介绍了一些有关对称密码体制诸如流密码和分组密码的内容。本文的主要内容则切换到公钥密码体制&#xff08;又称非对称密码体制&#xff09;&#xff0c;简述了公钥密码体制的基本思想和应用方…

2008年上半年软件设计师【上午题】真题及答案

文章目录 2008年上半年软件设计师上午题--真题2008年上半年软件设计师上午题--答案 2008年上半年软件设计师上午题–真题 2008年上半年软件设计师上午题–答案

微信小程序style动态绑定Object不生效处理方法

渲染的时候style变成了[Object Object] 解决方法: 给Object外面加一个[] <image :style"[imgStyle]" :src"url"></image>

算法学习笔记(8.1)-动态规划入门

目录 问题特性&#xff1a; 最优子结构&#xff1a; 代码示例&#xff1a;&#xff08;动态规划最优子结构&#xff09; 上述最小代价爬楼梯的运行过程&#xff1a; 代码示例&#xff1a; 无后效性&#xff1a; 解析&#xff1a; 具体过程图示如下&#xff1a; 具体的…

MAVLink代码生成-C#

一. 准备Windows下安装环境 Python 3.3 – 官网链接下载Python future模块 –pip3 install future TkInter (GUI 工具). – python for Windows自带&#xff0c;无需下载环境变量PYTHONPATH必须包含mavlink存储库的目录路径。 –set PYTHONPATH你的mavlink源码路径 源码下载在…

如何恢复永久删除的婚礼照片

我们的生活就像一本记忆剪贴簿&#xff0c;充满了褪色和模糊的快照。尽管我们想记住事情并留住快乐的回忆&#xff0c;但随着时间的流逝&#xff0c;它们会被冲走。为了避免这种情况并记住这些记忆&#xff0c;我们以照片的形式捕捉瞬间。这有助于缓解和分享那些快乐的时刻。但…

变阻器的故障排除方法有哪些?

变阻器&#xff0c;特别是滑动变阻器&#xff0c;作为电子电路中的常见元件&#xff0c;其故障排除方法主要依据具体的故障现象来确定。以下是一些常见的故障现象及其排除方法&#xff1a; 一、接触不良 现象&#xff1a;电阻器不起作用或电压不稳定。 排除方法&#xff1a; …

手撸俄罗斯方块(五)——游戏主题

手撸俄罗斯方块&#xff08;五&#xff09;——游戏主题 当确定游戏载体&#xff08;如控制台&#xff09;后&#xff0c;界面将呈现出来。但是游戏的背景色、方块的颜色、方框颜色都应该支持扩展。 当前游戏也是如此&#xff0c;引入了 Theme 的概念&#xff0c;支持主题的扩…

《面向对象分析与设计》读书笔记2

1、概念模型记录了系统中存在&#xff08;或者将存在&#xff09;的领域实体以及他们与系统中其他领域实体的关系&#xff0c;概念层的建模是利用业务领域的术语来完成的&#xff0c;应该是技术无关的。系统的逻辑视图利用了概念模型中创造的概念&#xff0c;建立起关键抽象和机…

flask模块化、封装使用缓存cache(flask_caching)

1.安装flask_caching库 pip install flask_caching 2.创建utils Python 软件包以及cache_helper.py 2.1cache_helper.py代码 from flask_caching import Cachecache Cache()class CacheHelper:def __init__(self, app, config):cache.init_app(app, config)staticmethoddef…

arm 、stm32、linux该如何学习?有没有先后顺序,先学什么比较好?

先讲自己&#xff0c;我是从Arduino单片机入门&#xff0c;再到stm32 &#xff0c;再开发瑞萨&#xff0c;TI&#xff0c;然后学校教了51。这是一个奇怪的学习过程&#xff0c;所以当我第一次接触51单片机的时候&#xff0c;刚好我有一些资料&#xff0c;是我根据网友给的问题精…

多个单元运算符合用???:::

string a "a";string b "b";string c "c";string r a "a" ? b "b" ? c"c" ? "b" : "cc" : "33":"44";string rr a "a"? b "b" ?(c …

PHP老照片修复文字识别图像去雾一键抠图微信小程序源码

&#x1f50d;解锁复古魅力&#xff0c;微信小程序黑科技大揭秘&#xff01;老照片修复&更多神奇功能等你来试&#xff01; &#x1f4f8; 【老照片修复&#xff0c;时光倒流的美颜术】 你是否珍藏着一堆泛黄的老照片&#xff0c;却因岁月侵蚀而模糊不清&#xff1f;现在…

buuctf zip伪加密

[BUUCTF]zip伪加密_buuctf zip伪加密-CSDN博客 借鉴以上博客 010打开 这两个位置是计算机判断是否为加密文件 两个都为09(奇数) 一般为真加密 两个为偶数(00)不加密 一个奇数一个偶数,伪加密 (注意,是一般) 这道题两个奇数,以为是真加密 暴力解码一下,解不出 看到题目提…

为服务器安全保驾护航的“三道防线”!

前言&#xff1a; 随着互联网的发展与普及&#xff0c;服务器安全性的保护变得越来越重要。服务器是企业和个人在网络中存储和处理敏感数据的重要设备&#xff0c;一旦服务器遭到未经授权的访问或攻击&#xff0c;可能导致数据泄露、系统崩溃等严重后果。因此&#xff0c;具备强…

ICC2:split_fanout如何插inverter pair

我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧? 拾陆楼知识星球入口 相关文章链接: ICC2:split fanout用法

【排序 - 堆排序】

堆排序&#xff08;Heap Sort&#xff09;是一种高效的排序算法&#xff0c;利用了堆这种数据结构的特性。堆排序的时间复杂度为 O(n log n)&#xff0c;并且是一个原地排序算法&#xff0c;不需要额外的存储空间。 堆的基本概念 堆是一种特殊的树形数据结构&#xff0c;分为…

用Racket做一个拼图游戏——4 实现工具

4 实现工具 思路理清楚了&#xff0c;接下来就一个一个功能实现。在阐述实现功能的编程过程中&#xff0c;会延伸讲解编程思路、相关的Racket函数及相关知识点&#xff0c;力图达到在实践中的学习目的。 在编程实现过程中&#xff0c;首先实现图片操作功能&#xff0c;再通过…