题解 | #Redraiment的走法#
Redraiment的走法
http://www.nowcoder.com/practice/24e6243b9f0446b081b1d6d32f2aa3aa
最长子序列,使用动态规划的思想即可解决
import java.util.Arrays; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); while (sc.hasNext()) { int size = Integer.parseInt(sc.nextLine().trim()); String[] strArr = sc.nextLine().trim().split(" "); int[] nums = new int[size]; int[] dp = new int[size]; Arrays.fill(dp,1); for (int i = 0; i < nums.length; i++) { nums[i] = Integer.parseInt(strArr[i]); } for (int i = 0; i < nums.length; i++) { for (int j = 0; j < i; j++) { if(nums[i]>nums[j]) dp[i]=Math.max(dp[i],dp[j]+1); } } int res = 0; for (int i = 0; i < dp.length; i++) { res = Math.max(res,dp[i]); } System.out.println(res); } } }