Redraiment的梅花桩走法

Redraiment的走法

http://www.nowcoder.com/questionTerminal/24e6243b9f0446b081b1d6d32f2aa3aa

也就是求最长上升子序列(Leetcode 300)

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextInt()) {
            int num = in.nextInt();
            int[] origin = new int[num];
            int[] dp = new int[num];
            int res = 0;
            //初始化输入的序列和dp数组
            Arrays.fill(dp,1);
            for(int x = 0; x < num; x++){
                origin[x] = in.nextInt();
            }
            //dp[i]表示:到i为止最长的序列长度
            for(int i = 1; i < dp.length; i++){
                for(int j = 0; j <= i; j++){
                    if(origin[j] < origin[i]){
                        dp[i] = Math.max(dp[i],dp[j] + 1);
                    }
                }
                res = Math.max(res, dp[i]);
            }
            System.out.println(res);
        }
    }
}
全部评论

相关推荐

Yki_:你要算时间成本呀,研究生两三年,博士三四年,加起来就五六年了,如果你本科去腾讯干五年,多领五年的年薪,加上公司内涨薪,可能到时候十五年总薪资也跟博士差不多
点赞 评论 收藏
分享
机械打工仔:我来告诉你原因,是因为sobb有在线简历,有些HR为了快会直接先看在线简历,初步感觉不合适就不会找你要详细的了
投了多少份简历才上岸
点赞 评论 收藏
分享
07-04 16:00
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务