一个数组,抽出几个数,使得剩下的数组有序且最长,编程题 java

时间: 2024-03-06 10:52:14 浏览: 16
这是一个经典的动态规划问题——最长递增子序列(Longest Increasing Subsequence,简称 LIS)问题。 我们可以使用动态规划的思想来解决这个问题。设 dp[i] 表示以第 i 个数为结尾的 LIS 的长度。因为最长递增子序列的结尾必须是原序列中的一个数,所以我们可以枚举结尾的数,然后对于每个结尾,枚举它前面所有比它小的数,计算以这些数为结尾的 LIS 的长度,然后取最大值加 1 就是以当前数为结尾的 LIS 的长度。状态转移方程如下: dp[i] = max{ dp[j] } + 1,其中 j < i 且 a[j] < a[i]。 最终的最长递增子序列的长度就是所有 dp[i] 中的最大值。如果我们需要输出具体的最长递增子序列,我们可以在计算 dp[i] 的同时,记录 dp[i] 的最优解的前一个数的下标。 以下是 Java 代码实现: ```java public static int[] findLIS(int[] nums) { int n = nums.length; int[] dp = new int[n]; int[] prev = new int[n]; Arrays.fill(prev, -1); int maxLen = 0, maxIdx = -1; for (int i = 0; i < n; i++) { dp[i] = 1; for (int j = 0; j < i; j++) { if (nums[j] < nums[i] && dp[j] + 1 > dp[i]) { dp[i] = dp[j] + 1; prev[i] = j; } } if (dp[i] > maxLen) { maxLen = dp[i]; maxIdx = i; } } int[] lis = new int[maxLen]; for (int i = maxIdx, j = maxLen - 1; i >= 0; i--) { if (dp[i] == j + 1) { lis[j--] = nums[i]; } } return lis; } ``` 该函数接受一个整数数组 nums,返回一个最长递增子序列。如果有多个最长递增子序列,返回任意一个即可。

相关推荐

最新推荐

recommend-type

java实现把两个有序数组合并到一个数组的实例

今天小编就为大家分享一篇java实现把两个有序数组合并到一个数组的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

C++实现两个有序数组的合并

主要为大家详细介绍了C++实现两个有序数组的合并,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

java 输入一个数字组成的数组(输出该数组的最大值和最小值)

主要介绍了java 输入一个数字组成的数组,输出该数组的最大值和最小值,需要的朋友可以参考下
recommend-type

Java 对象(数组)占多大空间(几个字节) 手把手做实验

命令行: java -XX:+PrintCommandLineFlags -version 查看jvm默认参数 分别是 -XX:+UseCompressedOops 和 -XX:+UseCompressedClassPointers 这2个参数都是默认开启(+代表开启,-代表关闭) UseCompressedOops:普通...
recommend-type

PHP将二维数组某一个字段相同的数组合并起来的方法

本文实例讲述了PHP将二维数组某一个字段相同的数组合并起来的方法。分享给大家供大家参考,具体如下: 例子: array(3) { [0]=&gt; array(16) { ["id"]=&gt; string(2) "42" ["uid"]=&gt; string(2) "14" ["euid"]=&gt; ...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

云原生架构与soa架构区别?

云原生架构和SOA架构是两种不同的架构模式,主要有以下区别: 1. 设计理念不同: 云原生架构的设计理念是“设计为云”,注重应用程序的可移植性、可伸缩性、弹性和高可用性等特点。而SOA架构的设计理念是“面向服务”,注重实现业务逻辑的解耦和复用,提高系统的灵活性和可维护性。 2. 技术实现不同: 云原生架构的实现技术包括Docker、Kubernetes、Service Mesh等,注重容器化、自动化、微服务等技术。而SOA架构的实现技术包括Web Services、消息队列等,注重服务化、异步通信等技术。 3. 应用场景不同: 云原生架构适用于云计算环境下的应用场景,如容器化部署、微服务
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。