【必看】DP经典类型题详解-考前刷分技巧

2024-02-26 02:28

本文主要是介绍【必看】DP经典类型题详解-考前刷分技巧,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

点赞关注不迷路!

1.装箱问题

P1049 [NOIP2001 普及组] 装箱问题 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

代码

// 洛谷 P1049
// 原题地址 https://www.luogu.com.cn/problem/P1049
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
int v;//容积
int n;//物品数
int a[35];
bool b[20005];//打钩数组
int main(){cin>>v>>n;for(int i=1;i<=n;i++){cin>>a[i];}b[0]=1;//必要边界for(int i=1;i<=n;i++){for(int j=v;j>=a[i];j--){if(b[j-a[i]]){b[j]=1;}}}for(int i=v;i>=0;i--){if(b[i]){cout<<(v-i)<<endl;return 0;}}return 0;
}

2.LIS(longest increasing sequence)最长上升子序列

B3637 最长上升子序列 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

代码

// 洛谷 B3637
// 原题地址:https://www.luogu.com.cn/problem/B3637
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
int n;
int a[5005];
int f[5005];
int main(){cin>>n;for(int i=1;i<=n;i++){f[i]=1;cin>>a[i];}for(int i=2;i<=n;i++){int maxv=0;for(int j=1;j<i;j++){if(a[i]>a[j]&&f[j]>maxv){maxv=f[j];}}f[i]+=maxv;}int maxv=0;for(int i=1;i<=n;i++){maxv=max(maxv,f[i]);}cout<<maxv<<endl;return 0;
}

3.贴邮票问题

P2725 [USACO3.1] 邮票 Stamps - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

代码

//P2725 [USACO3.1] 邮票 Stamps
//https://www.luogu.com.cn/problem/P2725
//63 points
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
int n,k;
int a[55];
int num[10005];
int main(){cin>>k>>n;int maxv=0;for(int i=1;i<=n;i++){cin>>a[i];num[a[i]]=1;maxv=max(maxv,a[i]);}int big=maxv;for(int i=2;i<=k;i++){for(int j=big;j>=1;j--){if(num[j]==1){for(int k=1;k<=n;k++){num[j+a[k]]=1;}}}big=i*maxv;}int i=1;while(num[i]==1) i++;cout<<i-1<<endl;return 0;
}

这篇关于【必看】DP经典类型题详解-考前刷分技巧的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/747450

相关文章

前端 CSS 动态设置样式::class、:style 等技巧(推荐)

《前端CSS动态设置样式::class、:style等技巧(推荐)》:本文主要介绍了Vue.js中动态绑定类名和内联样式的两种方法:对象语法和数组语法,通过对象语法,可以根据条件动态切换类名或样式;通过数组语法,可以同时绑定多个类名或样式,此外,还可以结合计算属性来生成复杂的类名或样式对象,详细内容请阅读本文,希望能对你有所帮助...

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.

Java 8 Stream filter流式过滤器详解

《Java8Streamfilter流式过滤器详解》本文介绍了Java8的StreamAPI中的filter方法,展示了如何使用lambda表达式根据条件过滤流式数据,通过实际代码示例,展示了f... 目录引言 一.Java 8 Stream 的过滤器(filter)二.Java 8 的 filter、fi

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

springboot的调度服务与异步服务使用详解

《springboot的调度服务与异步服务使用详解》本文主要介绍了Java的ScheduledExecutorService接口和SpringBoot中如何使用调度线程池,包括核心参数、创建方式、自定... 目录1.调度服务1.1.JDK之ScheduledExecutorService1.2.spring

MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)

《MySQL中的服务器配置和状态详解(MySQLServerConfigurationandStatus)》MySQL服务器配置和状态设置包括服务器选项、系统变量和状态变量三个方面,可以通过... 目录mysql 之服务器配置和状态1 MySQL 架构和性能优化1.1 服务器配置和状态1.1.1 服务器选项

Vue3中的动态组件详解

《Vue3中的动态组件详解》本文介绍了Vue3中的动态组件,通过`component:is=动态组件名或组件对象/component`来实现根据条件动态渲染不同的组件,此外,还提到了使用`markRa... 目录vue3动态组件动态组件的基本使用第一种写法第二种写法性能优化解决方法总结Vue3动态组件动态

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Debezium 与 Apache Kafka 的集成方式步骤详解

《Debezium与ApacheKafka的集成方式步骤详解》本文详细介绍了如何将Debezium与ApacheKafka集成,包括集成概述、步骤、注意事项等,通过KafkaConnect,D... 目录一、集成概述二、集成步骤1. 准备 Kafka 环境2. 配置 Kafka Connect3. 安装 D

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程