leetcode1312.让字符串成为回文串的最少插入次数

第一种写法:递归

java 复制代码
class Solution {
    private int minInsertions(String s, int left, int right) {
        //1.当字符串长度不超过1时不需要操作就已经是回文的了
        if (left >= right) {
            return 0;
        }
        //2。字符串长度超过1时
        //2.1字符串前后两个字符相等,不需要进行操作
        if (s.charAt(left) == s.charAt(right)) {
            return minInsertions(s, left + 1, right - 1);
        }
        //2.2字符串前后两个字符不相等,人为操作左或者右添加一个相等字符的操作数是1
        return 1 + Math.min(minInsertions(s, left + 1, right), minInsertions(s, left, right - 1));
    }
    public int minInsertions(String s) {
        return minInsertions(s, 0, s.length() - 1);
    }
}

第二种写法:记忆化搜索

java 复制代码
class Solution {
    private int[][] memory;
    private int minInsertions(String s, int left, int right) {
        //1.当字符串长度不超过1时不需要操作就已经是回文的了
        if (left >= right) {
            return 0;
        }
        //2.当记忆数组当中已经存储了这个值时,直接返回
        if (memory[left][right] != -1) {
            return memory[left][right];
        }
        //3。字符串长度超过1时
        //3.1字符串前后两个字符相等,不需要进行操作
        if (s.charAt(left) == s.charAt(right)) {
            return memory[left][right] = minInsertions(s, left + 1, right - 1);
        }
        //3.2字符串前后两个字符不相等,人为操作左或者右添加一个相等字符的操作数是1
        return memory[left][right] = 1 + Math.min(minInsertions(s, left + 1, right), minInsertions(s, left, right - 1));
    }
    public int minInsertions(String s) {
        memory = new int[s.length()][s.length()];
        for (int[] ints : memory) {
            Arrays.fill(ints, -1);
        }
        return minInsertions(s, 0, s.length() - 1);
    }
}

第三种写法:递推

java 复制代码
class Solution {
    public int minInsertions(String s) {
        int n = s.length();
        int[][] dp = new int[n][n];
        for (int i = n - 2; i >= 0; i--) {
            for (int j = i + 1; j < n; j++) {
                dp[i][j] = s.charAt(i) == s.charAt(j) ? dp[i + 1][j - 1] : 1 + Math.min(dp[i + 1][j], dp[i][j - 1]);
            }
        }
        return dp[0][n - 1];
    }
}
相关推荐
退休倒计时6 分钟前
【每日一题】LeetCode 19. 删除链表的倒数第 N 个结点 TypeScript
leetcode·链表·typescript
装不满的克莱因瓶33 分钟前
掌握生成对抗网络(GAN)的优化目标与评估指标——从博弈函数到生成质量衡量体系
人工智能·python·深度学习·算法·机器学习
技术小黑36 分钟前
CNN算法实战系列06 | InceptionV1实现猴痘病识别
深度学习·算法·cnn·inceptionv1
qq_2975746741 分钟前
设计模式系列文章(基础篇第22篇):访问者模式——分离数据结构与操作,实现灵活扩展
数据结构·设计模式·访问者模式
云淡风轻~窗明几净1 小时前
角谷猜想的任意算法测试
数据结构·人工智能·算法
代码中介商1 小时前
关键路径解析:项目管理的工期奥秘
数据结构
happygrilclh1 小时前
赚外快了:等离子表面处理机电源算法需求说明
算法
ji198594431 小时前
MATLAB 求散点曲线斜率
开发语言·算法·matlab
kaikaile19951 小时前
MATLAB 实现:Koch & Zhao 图像水印算法(DCT域)
开发语言·算法·matlab
love_muming1 小时前
链表每日一练
java·开发语言·数据结构·链表·idea·每日一练