[kuangbin]基础dp

Max Sum Plus Plus

        题目大意:从一串数组中挑选连续m段子数组,使得最后的sum最大。

        思路:首先考虑开二维数组,那么动态转移方程为:

        dp[i][j]=max(dp[i-1][k]+a[j],dp[i][j-1]+a[j])

        其中dp表示枚举到第 j 个数的时候,已经挑选了 i 段子数组,最大的sum值。

        那么后面的转移方程:表示该段正在枚举,或者是新的一串子数组。

        那么二维太大了,改成一维数组,那么上一个k位置表示 i - 1 段的时候的最大值,因此可以开一个新的数组来表示上一段的最大值。

       代码附上:

#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N = 1e6+5;
int n,m;
int a[N];
int dp[N],f[N];//dp[i][j]表示枚举到j恰好有i组
//dp[i][j]=max(dp[i-1][k]+a[j],dp[i][j-1]+a[j]);void solve(){memset(dp,0,sizeof(dp));memset(f,0,sizeof(f));cin>>n;for(int i=1;i<=n;i++)cin>>a[i];int max1;for(int i=1;i<=m;i++){max1=-0x3f3f3f3f3f3f;for(int j=i;j<=n;j++){dp[j]=max(dp[j-1]+a[j],f[j-1]+a[j]);f[j-1]=max1;max1=max(dp[j],max1);}}cout<<max1<<"\n";}signed main(){ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);int t=1;while(cin>>m&&m!=0){solve();}return 0;
}

Monkey and Banana

一块砖头有6种方式去摆放(1,2,3)(1,3,2)(2,1,3)(2,3,1)(3,1,2)(3,2,1)

上面的砖头长(l) ,宽(s)必须分别小于下面的

dp[i]为第i个砖头是最下面的那个砖头时候 可以达到的最大高度

代码附上:
 

#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N = 1e6+5;
int n;
struct node{int x,y,z;bool operator<(const node &u)const{if(u.x==x){return y<u.y;}return x<u.x;}
};
int dp[N];
vector<node>g;void _main_main(){memset(dp,0,sizeof(dp));g.clear();for(int i=1;i<=n;i++){int x,y,z;cin>>x>>y>>z;g.push_back({x,y,z});g.push_back({x,z,y});g.push_back({y,z,x});g.push_back({y,x,z});g.push_back({z,x,y});g.push_back({z,y,x});}//所有的状态都存上sort(g.begin(),g.end());int ans=0;for(int i=0;i<g.size();i++){dp[i]=g[i].z;for(int j=i-1;j>=0;j--){//枚举前面比它小的长和宽if(g[j].x<g[i].x&&g[j].y<g[i].y&&dp[j]+g[i].z>dp[i]){dp[i]=dp[j]+g[i].z;ans=max(ans,dp[i]);}}}cout<<ans<<"\n";}signed main (){ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);int tt=1;while(cin>>n&&n!=0){cout << "Case " << tt << ": " ;cout<<"maximum height = ";tt++;_main_main();}
}

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

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

相关文章

【深度学习(42)】通过vscode使用anaconda的python环境

按ctrlshiftp&#xff0c;选择Python:Select Interpreter 选择anaconda下的python虚拟环境

Elasticsearch 高亮搜索结果:提升用户体验的关键技术

在构建搜索引擎或任何需要快速、准确信息检索的应用时&#xff0c;搜索结果的高亮显示是一项至关重要的功能。它不仅能够显著提升用户的搜索体验&#xff0c;还能帮助用户更快地定位到他们感兴趣的内容。Elasticsearch&#xff0c;作为当今最流行的开源搜索和分析引擎之一&…

【k8s安装redis】k8s环境无pvc的情况下安装redis哨兵集群

文章目录 简介一.条件及环境说明&#xff1a;二.需求说明&#xff1a;三.实现原理及说明四.详细步骤4.1.规划节点标签4.2.创建configmap配置4.3.创建三个statefulset和service headless配置4.4.创建哨兵deployment配置和service配置 五.安装说明 简介 k8s集群中搭建有状态的服务…

大模型备案全网最详细流程说明【附附件】

下图为最新的直至第五批深度合成服务算法备案信息的公告 根据目前公开的国内大模型算法备案统计来看&#xff0c;首批境内深度合成服务算法备案清单&#xff0c;总共通过了五批。 以第二批举例&#xff0c;境内深度合成服务算法备案清单&#xff0c;总共通过110家&…

秒与时间转换器

目录 开头程序程序的流程图程序输入与输出的效果例1输入输出 例2输入输出 例3输入输出 结尾 开头 大家好&#xff0c;我叫这是我58。在这里&#xff0c;我要给大家介绍一下我用C语言编译的秒与时间转换器和与之相关的一些东西。 程序 #define _CRT_SECURE_NO_WARNINGS 1 #in…

基于FaceX-Zoo里的faceSDK实现人脸识别(与人脸库结合比对人脸)

目录 一、简介 二、face SDK 1、环境需要 2、功能实现 2.1人脸库搭建 2.2人脸识别 3、测试结果 4、总结 本文根据京东开源的人脸识别工具包FaceX-Zoo,实现了人脸识别功能。对代码中的faceSDK部分做了修改,并搭建了自己的人脸库,识别结果准确度较高,后期可以打包SDK…

HTTP Client

从jdk9开始引入HTTP Client标准化,在jdk10开始更新。通过CompletableFutures提供了非阻塞请求和响应式。流量控制在java.util.concurrent.Flow API提供支持。更容易的跟踪数据流:从用户请求发布者和响应订阅者,一直到底层套接字。 public void get(String uri) throws Exce…

uni app for()在App上不运行

项目场景&#xff1a; uniapp单选 文字 显示 text &#xff1a; 问题描述 h5 有效 安卓App 无效 for(var i 0;i<from.length();i){}解决方案&#xff1a; this.from.forEach((itme,index)>{this.sex.push({value:itme.nodeCode,text:itme.nodeName});this.sex1.pus…

Python的异常处理(与C++对比学习)

一、C语言中错误的处理方式 用assert来判断一个表达式是否出错&#xff1b;在调用接口函数时&#xff0c;接口函数会设置errno&#xff0c;我们可以通过errno&#xff0c;strerror(errno)来拿到错误码和错误信息。在自定义函数中&#xff0c;我们设置函数错误信息处理的时候&a…

告别堆积,迎接清新:回收小程序,打造无废生活新选择

在快节奏的现代生活中&#xff0c;物质的丰富与便利似乎成为了我们日常的一部分&#xff0c;但随之而来的&#xff0c;是日益增长的废弃物堆积问题。街道边、社区里&#xff0c;甚至是我们的家中&#xff0c;废弃物品仿佛无孔不入&#xff0c;逐渐侵蚀着我们的生活空间与环境质…

element-tree树半勾选+根据id查找树的某一项

需要添加定时器才可以及时勾选上 // 半勾选回显permissions && permissions.forEach(item > {const a setTimeout(() > {this.$nextTick(() > {this.$refs.menuTreeRef.setChecked(Number(item), true, false)clearTimeout(a)})this.$forceUpdate()}, 100)})…

基于Netty的自研流系统缓存实现挑战: 内存碎片与OOM困境

01 前言 Kafka 作为流处理平台&#xff0c;在实时流计算和在线业务场景&#xff0c;追尾读追求端到端低延迟。在离线批处理和削峰填谷场景&#xff0c;数据冷读追求高吞吐。两个场景都需要很好的数据缓存设计来支撑&#xff0c;Apache Kafka 的数据存储在本地文件&#xff0c…

抖音蓝V商家采集软件使用指南

抖音是目前非常流行的短视频平台之一&#xff0c;许多商家在抖音上通过发布视频来推广自己的产品和品牌。而蓝V商家采集软件是一款可以帮助商家快速采集蓝V用户信息的工具。本文将为大家介绍如何使用抖音蓝V商家采集软件&#xff0c;并提供相应的代码示例。 安装和配置抖音蓝V商…

pointnet2_ops_lib/.安装报错解决方案

问题 3D点云相关的代码例如pointnn、pointmlp都需要安装pointnet2_ops&#xff0c;可是基本上在安装pointnet2_ops时总会报错&#xff0c;终归原因是虚拟环境的cuda版本和安装的torch&#xff0c;torchvision&#xff0c; torchaudio版本不一致导致。 方案 这里以pointmlp&am…

智能信息检索:布尔查询

函数介绍&#xff1a; 本次实验利用了上一次实验构建成功的倒排表 send为评测提交函数 and_search为AND逻辑布尔查询 and_search_sort增添了相关度排序的功能 mul_search函数接受不同参数来确定查询的逻辑 test支持用户手动输入测试 代码实现&#xff1a; bool_search.…

Sharding-JDBC分库分表之SpringBoot主从配置

Sharding-JDBC系列 1、Sharding-JDBC分库分表的基本使用 2、Sharding-JDBC分库分表之SpringBoot分片策略 3、Sharding-JDBC分库分表之SpringBoot主从配置 前言 在开发中&#xff0c;如果对数据库的读和写都在一个数据服务器中操作&#xff0c;面对日益增加的访问量&#x…

解锁算力新极限,Xilinx UltraScale+赋能的高性能低延时FPGA加速卡

01、产品概述 AiHPC-V9P 是一款基于 AMD Virtex UltraScale FPGA VU9P 的 PCIe Gen3.0 x16 接口智能网卡&#xff0c;具有最大2*200GbE /或者16*10GbE(典型应用&#xff09;接入容量的高性能低延时智能网卡。 对外接口支持两组QSFP-DD 最高25Gb/s x8Lane 光口接入&#xf…

数据库系统概论 | MySQL | 数据定义 | 单表查询 | 嵌套查询 | 连接查询 | 带有谓词的查询

数据定义 模式的定义与删除 定义模式与删除模式&#xff1a; CREATE SCHEMA S_C_SC; DROP SCHEMA S_C_SC;进入模式&#xff1a; USE S_C_SC;建立学生表&#xff1a; CREATE TABLE Student (Sno CHAR(8) PRIMARY KEY, Sname VARCHAR(20) UNIQUE, Ssex CHAR(6), Sbirthdate …

【Sql Server】sql server 2019设置远程访问,外网服务器需要设置好安全组入方向规则

大家好&#xff0c;我是全栈小5&#xff0c;欢迎来到《小5讲堂》。 这是《Sql Server》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解。 温馨提示&#xff1a;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff01; 目录 前言1、无法链接…

分享四款常见的内网穿透工具

本文精心筛选了四款业内领先的内网穿透解决方案&#xff1a;巴比达、花生壳、Frp及NatApp&#xff0c;旨在全面展现它们在安全、便捷与灵活性方面的独到之处&#xff0c;尤其是对花生壳、Frp和NatApp进行了详尽补充&#xff0c;以帮助读者更好地理解这些工具的内在价值。 1. 巴…