2023.9.1最长上升子序列

56368795

最长上升子序列:5679(严格小于号连接,LIS

最长不降子序列:56679(<=连接,LNDS

最长下降子序列:875(LDS

最长不升子序列:665(LNIS

上升子序列最小划分数:划分成多个上升子序列,问最少分几个

5679,35,68

贪心:设d[i]表示第i个上升子序列的末尾的值(不断更新,dp表上的值越来越大)

自变量是扫到的序列编号(只会往后走,不会往前,前面的都已经排好了)

从左往右更新,即第一个总是保持最大的编号

扫到arr[1]时存到d[1],此时d[1]=5

扫到2号时,2号为6比d[1]大,所以可以存到第一个上升子序列,更新d[1]=6

扫到3号时,比d[1]=6小,那么不能存到它后面,所以要新建一个序列,d[2]=3

扫到4号时,比和d[1]=6相等,由于是上升子序列,所以还是要存到第二个子序列里,更新d[2]=6,

扫到5号,比d[1]=6大,更新d[1]=8,

……

最后发现d数组最多到i=3位,所以最少需要3个上升子序列就可以完成对串的划分

//dp存储到第n个导弹,可以拦截多少个
// 改一下,改为以第N个导弹拦截为结尾的拦截总数
//每次来后,都可以选择拦或不拦
// 怎么体现,现在写的是确定第n个导弹拦截的情况
//打表顺序从小到大,从左到右
//一个参数是当前可拦的最大高度,不超过上一个拦的高度,凭此进行选择
//一个参数是第几个导弹
//到第n个导弹,就有N-1种选择,即上一次拦的导弹是第几个
//dp() {
//	for (int i = 1; i <= n - 1; i++) {//选择上一个拦截导弹序号
//		if (arr[n] <= arr[i]) {//只有高度不大于上一个才可以拦截
//			dp[n] = max(dp[n], dp[n - i] + 1);
//		}
//	}
//}
//要问所需的最少系统书
//贪心,让所有现在的导弹拦截高度由大到小排(优先队列,小顶堆)
//然后让这个导弹高度从最小的开始逐步往大的去比
//如果现在的高度比拦截高度最小的小
//那就让最小的更新为这个高度(即总是保留大的高度,以此来拦截未来可能更高的导弹)
//如果最小的拦不了,那就逐渐往后比,直到能比到一个比拦截高度小的
//如果都没有,那就新建一个系统,让新系统拦截这个导弹
//
// 类比哈斯图,第一问就是求最长哈斯图长度
// 第二问就是问至少需要几条链才能覆盖哈斯图
// Dilworth定理:设A种最长链长度为n,则将A种元素分成不相交的反链,反链个数至少是n
// 最大反链中元素的数目必等于最小链划分(即用最少的链数组合成一个哈斯图)中链的数目
// 什么叫不相交的反链?
// 什么是反链
// 反链是指偏序集每两个元素都是无关的子集
// 不相交的反链即是不上升子序列
// 哈斯图中,若链相交,则说明可比,即之间有连线,则一定有上升关系
// 若不相交,则不可比,那么组合在一起就是不上升子序列
// 最少的不上升子序列的个数就是最长上升子序列的长度
//
int n=0,dp[num], arr[num];
int main() {/*cin >> n;for (int i = 1; i <= n; i++) {cin >> arr[i];}*/int x;while (cin >> x) { arr[++n] = x; }dp[1] = 1;int maxnum = dp[1];for (int i = 2; i <= n; i++) {//dp表填完for (int j = 1; j <= i - 1; j++) {//每次填表的流程if (arr[i] <= arr[j]) {dp[i] = max(dp[i], dp[j] + 1);maxnum = max(maxnum, dp[i]);//选择j为上一个拦截的导弹,就在上一个的基础上加上这个导弹}}}cout << maxnum << endl;//int cnt = 1,g[100];//至少用一个系统,至多用n个系统//g[1] = arr[1];//因为要拦截所有导弹,所以第一个系统必须拦截第一个导弹//for (int i = 1; i <= n; i++) {//从第一个导弹开始//	int k = 1;//指向当前系统//	//g[k]表示当前系统的最大拦截量,下标为系统编号//	while (k <= cnt && g[k] < arr[i]) { k++; }//一直访问到gk>=ai,即当前导弹能拦截了//	//或者超出现在已有数量,即现在系统都拦不了//	if (k > cnt)(g[++cnt]) = arr[i];//	else g[k] = arr[i];//}//cout << cnt;//设dpi表示以i结尾的最长不下降子序列长度//不下降子序列的最少个数为最长上升子序列的长度return 0;
}

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

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

相关文章

MIB 变更周期

MIB 始终以 80 ms 的周期在 BCH 上传输并在 80 ms 内重复&#xff0c;并且它包括从小区获取 SIB1 所需的参数&#xff1b;如果 SSB 的周期大于 80 ms&#xff0c;则 MIB 的发送周期与 SSB 的周期相同。 在UE初始搜索时&#xff0c;SSB在半帧内的周期是20ms&#xff1b;所以对于…

Kotlin Collection KTX:让你的集合操作如丝般顺滑

当今移动应用开发&#xff0c;常常需要使用各种集合类型来存储和操作数据。Kotlin 提供了 Collection KTX 扩展库&#xff0c;为我们操作集合提供了非常方便的 API。在本篇文章中&#xff0c;我们将介绍 Collection KTX 中包含的所有扩展函数&#xff0c;让你的集合操作变得更加…

2024系统分析师---论软件的可靠性设计

摘要&#xff1a; 本人于2018年1月参与了中石化XX油田XX采油厂“用电管理系统”的项目建设&#xff0c;该系统建设目标是实现分单位、分线路、分系统评价、优化、考核&#xff0c;全面提升采油厂用电管理水平。在该项目组中我担任系统架构师一职&#xff0c;主要负责系统整体架…

Linux第23步_安装windows下的stm32cubeprogram软件

stm32cubeprogram软件是通过USB3.0接口烧写系统软件。 1、双击“05、开发工具\02、ST官方开发工具\en.stm32cubeprog_v2-5-0\SetupSTM32CubeProgrammer-2.5.0.exe”。 2、点击“Next” 3、点击“Next” 4、勾选“I agree”&#xff0c;点击“Next” 5、点击“Next” 6、点…

阴盘奇门八字排盘马星位置计算方法php代码

如下位置&#xff0c;马星的四个位置。 计算方法&#xff1a; 1。先根据出生年月日&#xff0c;计算得八字四柱。比如 2024年01月09日&#xff0c;四柱为 其中时柱地支为“申” 2。然后根据以下对应的数组&#xff0c;来找到id号&#xff0c;即马星位置。 根据下表来找到&am…

iPhone语音备忘录怎么导出?这3种方法任你选择!

作为iPhone用户&#xff0c;我们应该会经常使用语音备忘录来记录一些重要的信息。有时候&#xff0c;我们可能需要将这些语音备忘录导出&#xff0c;以方便分享或备份。iphone语音备忘录怎么导出&#xff1f;今天&#xff0c;小编将为大家介绍3种导出iPhone语音备忘录的方法&am…

阿里云RDMA通信库XRDMA论文详解

RDMA(remote direct memory access)即远端直接内存访问&#xff0c;是一种高性能网络通信技术&#xff0c;具有高带宽、低延迟、无CPU消耗等优点。RDMA相比TCP在性能方面有明显的优势&#xff0c;但在编程复杂度上RDMA verbs却比TCP socket复杂一个数量级。 开源社区和各大云厂…

fpga目前就业形势咋样?

FPGA今年各厂给本科生的薪资大概是15-30K&#xff0c;研究生是20-40K&#xff0c;平均薪资在25k左右&#xff0c; 当然具体薪资还要看去哪个公司&#xff0c;哪个城市&#xff0c;以及个人的学校、专业、能力水平、及包括面试时的表现&#xff0c;运气等&#xff0c;这些都会导…

雍禾植发袁宣心中有“术”,雍禾医疗帮用户重启人生

从公立医院烧伤外科来到雍禾&#xff0c;可以说是袁宣职业生涯里最重要的一个决定。据了解&#xff0c;袁宣医生所在的雍禾植发&#xff0c;是国内最大的毛发医疗机构。截至2022年12月31日&#xff0c;雍禾医疗已组建1341人的专业医疗团队&#xff0c;其中毛发医生294人&#x…

从零实现一套低代码(保姆级教程) --- 【15】实现轮播图组件并增加容器子节点类型的控制

摘要 接上一篇&#xff0c;我们继续实现另外一个比较常见的组件。轮播图&#xff0c;在一些官网的页面中&#xff0c;这个组件是非常常见的。 如果你是第一次看到这一篇文章&#xff0c; 建议先看一下第一节内容&#xff1a; 从零实现一套低代码&#xff08;保姆级教程&#…

一个Pygame的Hello World示例程序

创建一个标题为Hello World的窗口&#xff0c;窗口中间显示有Pygame的Logo的python代码 import sys import pygamedef main():pygame.init()screen pygame.display.set_mode((800, 400))pygame.display.set_caption("Hello World")logo pygame.image.load("p…

2024 年 API 管理新趋势预测

本文译自&#xff1a;What Will Be the API Management Trends for 2024&#xff1f; 原文链接&#xff1a;What Will Be the API Management Trends for 2024? - The New Stack 原文作者&#xff1a;Kenn Hussey 预计到 2030 年末&#xff0c;API 管理 市场的规模将增长六倍&…

frp 通过自定义域名访问内网的 Web 服务 --来自官网

通过自定义域名访问内网的 Web 服务 通过简单配置 HTTP 类型的代理&#xff0c;您可以让用户通过自定义域名访问内网的 Web 服务。 HTTP 类型的代理非常适合将内网的 Web 服务通过自定义域名提供给外部用户。相比于 TCP 类型代理&#xff0c;HTTP 代理不仅可以复用端口&#…

压测clickhouse性能相关参数

背景&#xff1a;压测ck性能一直上不去&#xff0c;但是ck负载不大。尝试调整参数&#xff0c;验证是否有性能提升 1、background_common_pool_size Sets the number of threads performing background non-specialized operations like cleaning the filesystem etc. for ta…

为什么是设置512,1024之类的像素大小

选择 (512 \times 512)、(1024 \times 1024) 等像素大小的原因与计算机科学中的一些基本概念有关&#xff1a; 二进制和内存对齐&#xff1a;计算机系统基于二进制运作&#xff0c;因此处理二的幂次方的数值&#xff08;如 (2^9 512), (2^{10} 1024) 等&#xff09;时更为高效…

php 的判断语句

目录 1.if 2.else 3.elseif /else if 4.while 5.do-while 6.for 7.foreach 8.break 打断 9.contiun 继续 10.switch 1.if 判断语句为 true 则执行 if 里面的语句&#xff0c;否则不执行&#xff1b; <?php header("Content-Type: text/html; charsetutf-8&…

C++ Primer 第五版 中文版 阅读笔记 + 个人思考

C Primer 第五版 中文版 阅读笔记 个人思考 第 10 章 泛型算法10.1 概述练习10.1练习10.2 第 10 章 泛型算法 泛型的体现&#xff1a;容器类型&#xff08;包括内置数组&#xff09;&#xff0c;元素类型&#xff0c;元素操作方法。 顺序容器定义的操作&#xff1a;insert&a…

Web开发SpringBoot SpringMVC Spring的学习笔记(包含开发常用工具类)

开发框架学习笔记 一.Spring SpringMVC SpringBoot三者的联系SpringMVC工作原理 二.SpringBoot的学习框架学习 2.各个类之间的继承和实现关系3.理解面向对象的思想(其实这个想写在2中的)四.开发常用工具Lombok4.0说在前面(如何快速使用Lombok)4.1了解Lombok4.2Lombok的作用一:减…

搜索二维矩阵【二分】

Problem: 74. 搜索二维矩阵 文章目录 思路 & 解题方法复杂度二分两次二分一次 思路 & 解题方法 可以二分一次&#xff0c;也可以二分两次。 复杂度 时间复杂度: 添加时间复杂度, 示例&#xff1a; O ( l o g n l o g m ) O(logn logm) O(lognlogm) 空间复杂度: 添加…