身高排序+LIS

叠罗汉II

http://www.nowcoder.com/questionTerminal/4d55fae4236a4e09b8a3244ffc084dfc

LIS问题,如果题目没有规定顺序的话,应该排序之后再动态规划,这样可以保证最后的值为最优解。

import java.util.*;
public class Stack {
    public int getHeight(int[][] actors, int n) {
        int[] dp = new int[n];
        int max = 1;
        Arrays.fill(dp,1);
        // 这里用Comparator对身高进行排序
        Arrays.sort(actors, new Comparator<int[]>() {
            @Override
            public int compare(int[] ints, int[] t1) {
                return ints[0] - t1[0];
            }
        });
        // 求最长子序列
        for (int i = 1; i < n; i++) {
            int x= actors[i][0];
            int y= actors[i][1];
            for (int m = 0; m < i; m++) {
                if(x > actors[m][0] && y > actors[m][1]){
                    int k = dp[m] + 1;
                    dp[i] = k>dp[i]?k:dp[i];
                }
            }
            max = dp[i]>max?dp[i]:max;
        }
        return max;
    }
}
全部评论

相关推荐

不懂!!!:感觉你的项目描述太简单了,建议使用star描述法优化提炼一下,就是使用什么技术或方案解决了什么问题,有什么效果或成果,例如:对axios进行了二次封装,实现了请求的统一管理、错误的集中处理以及接口调用的简化,显著提高了开发效率和代码维护性,使用canvas技术实现了路线绘制功能,通过定义路径绘制函数和动态更新机制,满足了简化的导航可视化需求,提升了用户体验。像什么是使用其他组件库,基本功能描述就最好不要写到项目成果里面去了,加油
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务