题解 | #递减种子序列#
递减种子序列
https://www.nowcoder.com/practice/708a3a8603274fc7b5732c5e73617203
知识点:动态规划
对于动态规划类的题目,一个难点是定义出状态,另一个难点是找出状态转移方程。这道题中,我们可以定义dp[i]为i位置可以得到的最长递减序列长度,当我们获得了0到i-1位置的最长递减序列长度时,对于i位置来说,我们只需要依次判断是否能与前序列形成递减关系,若可以,则最长递减序列的长度+1,作为当前位置的最长序列递减长度。同时,遍历每个位置能够达到的最长递减序列长度,最大值即为答案。
Java题解如下
import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param seeds int整型一维数组 * @return int整型 */ public int lengthOfLIS (int[] seeds) { // write code here int n = seeds.length; int[] dp = new int[n]; Arrays.fill(dp, 1); int max = 1; for(int i = 1; i < n; i++) { for(int j = 0; j < i; j++) { if(seeds[j] > seeds[i]) { dp[i] = Math.max(dp[i], dp[j] + 1); max = Math.max(max, dp[i]); } } } return max; } }