题解 | #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);
        }
    }
}
全部评论

相关推荐

03-09 13:40
上海大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务