每日三题-最长回文子串、搜索二维矩阵II、最长递增子序列

简介: 每日三题-最长回文子串、搜索二维矩阵II、最长递增子序列

最长回文子串


88206b297c214df990edf4dd510a5a05.png

解法一

dp

class Solution {
    public String longestPalindrome(String s) {
        char[] c = s.toCharArray();
        int str = s.length();
        boolean dp[][] = new boolean[str][str];
        // dp[i][j] = c[i]==c[j] && dp[i+1][j-1];
        int left = 0; // 左下标
        int right = 0; // 右下表
        int maxlen = 1; //长度  
        for(int i = 0;i < str;i++){
            dp[i][i] = true;
        }
        for(int len = 2;len <= str;len++){//枚举长度
            for(int i = 0;i < str;i++){//枚举起点
                int j = i+len-1; // j 是终点
                if(j >= str){
                    break;
                }
                if(c[i]==c[j] && (dp[i+1][j-1] || j-i ==1 )){
                    dp[i][j] = true;
                    if(j-i+1 > maxlen){
                        maxlen = j-i+1;
                        left = i;
                        right = j;
                    }
                }
            }
        }        
        return s.substring(left,right+1);
    }
}


搜索二维矩阵II


e2f4ab4f73cf42a4b81cafb0c3ea697a.png

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int m = matrix.length;
        int n = matrix[0].length;
        int i = 0;
        int j = n-1;
        while(i < m && j >= 0){
            if(target == matrix[i][j]){
                return true;
            }else if(target > matrix[i][j]){
                i++;
            }else {
                j--;
            }
        }
        return false;
    }
}


最长递增子序列


60a2ae8226ae4aef92bad20480bb0e3a.png

class Solution {
    public int lengthOfLIS(int[] nums) {
        int len = nums.length;
        int dp[] = new int[len];
        int maxans = 0;
        for(int i = 0;i < len;i++){
            for(int j = 0;j < i;j++){
                if(nums[j]<nums[i]) dp[i] = Math.max(dp[i],dp[j]+1);
            }
            maxans =Math.max(dp[i],maxans);
        }
        return maxans+1;
    }
}
相关文章
|
8月前
【题型总结】动态规划之按照某种形式分割数组以获得最值
【题型总结】动态规划之按照某种形式分割数组以获得最值
81 0
|
8月前
|
机器学习/深度学习 算法 测试技术
【组合数学 容斥原理 逆向思考】2930. 重新排列后包含指定子字符串的字符串数目
【组合数学 容斥原理 逆向思考】2930. 重新排列后包含指定子字符串的字符串数目
|
7月前
|
存储 算法 数据可视化
深入解析力扣161题:相隔为 1 的编辑距离(逐字符比较与动态规划详解)
深入解析力扣161题:相隔为 1 的编辑距离(逐字符比较与动态规划详解)
|
7月前
|
存储 算法
算法训练,牛客.判断是不是平衡二叉树 牛客.最大子矩阵两个数组的交集牛客.数组中两个字符串的最小距离
算法训练,牛客.判断是不是平衡二叉树 牛客.最大子矩阵两个数组的交集牛客.数组中两个字符串的最小距离
算法训练,牛客.判断是不是平衡二叉树 牛客.最大子矩阵两个数组的交集牛客.数组中两个字符串的最小距离
|
7月前
|
算法
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
|
7月前
|
算法
【经典LeetCode算法题目专栏分类】【第8期】滑动窗口:最小覆盖子串、字符串排列、找所有字母异位词、 最长无重复子串
【经典LeetCode算法题目专栏分类】【第8期】滑动窗口:最小覆盖子串、字符串排列、找所有字母异位词、 最长无重复子串
|
人工智能 BI
牛客 序列排列1
牛客 序列排列1
68 0
|
8月前
|
算法
【Leetcode 74】搜索二维矩阵 —— 二分查找|矩阵
给你一个满足下述两条属性的`m x n`整数矩阵:每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数
|
8月前
|
算法 测试技术 C#
C++前缀和算法:统计美丽子字符串
C++前缀和算法:统计美丽子字符串
|
8月前
|
算法 程序员 索引
【算法训练-动态规划 三】【双序列DP问题】最长重复子数组、最长公共子串、最长公共子序列、编辑距离
【算法训练-动态规划 三】【双序列DP问题】最长重复子数组、最长公共子串、最长公共子序列、编辑距离
120 0