LeetCode算法题

简介: LeetCode算法题

题目1.最长回文字符串

这题为动态规划(主要是找到状态转移方程)的子序列问题

解题思路:

状态表示:dp[i][j]表示字符串的闭区间[i,j]内是否为回文字符串

  状态转移方程:当s[i]==s[j]的时候

         情况1:i==j;dp[i][j]为回文字符串;

         情况2:j-i==1;dp[i][j]为回文字符串;

         情况3:下标:i 与 j相差大于1的时候,例如cabac,此时s[i]与s[j]已经相同了,我们看i到j区间是不是回文子串就看aba是不是回文就可以了,那么aba的区间就是 i+1 与 j-1区间,这个区间是不是回文就看dp[i + 1][j - 1]是否为回文字符串。

 求解时i,j的顺序

     

 

如果这矩阵是从上到下,从左到右遍历,那么会用到没有计算过的dp[i + 1][j - 1],也就是根据不确定是不是回文的区间[i+1,j-1],来判断了[i,j]是不是回文,那结果一定是不对的。

所以一定要从下到上,从左到右遍历,这样保证dp[i + 1][j - 1]都是经过计算的。

提交代码:

char * longestPalindrome(char * s){
    int i,j,left=0,right=0,dp[1001][1001]={0},max=0,k=0;
    char *p=malloc(sizeof(char)*1001);
    int len=strlen(s);
    for(i=len-1;i>=0;i--)
    {
        for(j=i;j<len;j++)
        {
            if(s[i]==s[j])
            {
                if(j==i)
                   dp[i][j]=1;
                if(j-i==1)
                   dp[i][j]=1;
                if(j-i>1)
                {
                    if(dp[i+1][j-1]==1)
                    {
                        dp[i][j]=1;
                    }
                }
            }
            if(dp[i][j]==1)
            {
               if(j-i+1>max)
               {
                   max=j-i+1;
                   left=i;
                   right=j;
               }
            }
        }
    }
    for(i=left;i<=right;i++)
    {
        p[k++]=s[i];
    }
    p[k]='\0';
    return p;
}


目录
相关文章
|
2月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
40 0
|
22天前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
2月前
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
28 2
|
4月前
|
算法
测试工程师的技能升级:LeetCode算法挑战与职业成长
这篇文章通过作者亲身体验LeetCode算法题的过程,探讨了测试工程师学习算法的重要性,并强调了算法技能对于测试职业成长的必要性。
70 1
测试工程师的技能升级:LeetCode算法挑战与职业成长
|
4月前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
52 6
|
4月前
|
存储 算法 Java
LeetCode经典算法题:打家劫舍java详解
LeetCode经典算法题:打家劫舍java详解
70 2
|
4月前
|
人工智能 算法 Java
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
52 1
|
4月前
|
存储 算法 Java
LeetCode经典算法题:预测赢家+香槟塔java解法
LeetCode经典算法题:预测赢家+香槟塔java解法
61 1
|
4月前
|
存储 算法 Java
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
80 0
|
4月前
|
算法 Java
LeetCode初级算法题:子数组最大平均数+二叉树的最小深度+最长连续递增序列+柠檬水找零
LeetCode初级算法题:子数组最大平均数+二叉树的最小深度+最长连续递增序列+柠檬水找零
43 0