最长递增子序列A

import java.util.Scanner;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
// write code here
public class Main {
    public static void main(String args[]) {
        Scanner in = new Scanner(System.in);
        while (in.hasNext()) {
            int a = in.nextInt();
            for (int i = 0; i < a; i++) {
                int b = in.nextInt(),maxCount=1;                
                int[] dp = new int[b];
                int[] arr = new int[b];
                for (int j = 0; j < b; j++) {
                    arr[j] = in.nextInt();
                    dp[j]=1;
                }
                for (int k = 1; k < b; k++) {
                    for (int l = 0; l < k; l++) {
                        if (arr[k] > arr[l] && dp[l] + 1 > dp[k]) {
                            dp[k] = dp[l] + 1;
                        }
                    }
                    if (maxCount < dp[k]) {
                        maxCount = dp[k];
                    }
                }
                System.out.println(maxCount);
            }
        }
    }
}

全部评论

相关推荐

05-09 13:22
门头沟学院 Java
点赞 评论 收藏
分享
Java抽象带篮子:简历怎么写可以看看我发的帖子,你的第一个是实习经历吗?那怎么写的是你的第一个练手项目呢?简历写的怎么样直接投小厂面试一下就知道了
没有实习经历,还有机会进...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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