【Leetcode】1930. 长度为 3 的不同回文子序列

这一题题目不难理解,就是在字符串中寻找有多少个独一无二的回文,只不过这个回文可以不相邻,而且长度只有3。固定首尾,然后再确定中间的字符,加一个去重即可(Set)。

时间复杂度过大,n的3次方

这里的思路比较耿直,直接用3层循环来做
i来寻找首,j来寻找尾,k在中间进行累加即可

最后利用set来进行去重

只不过这里不能ac,时间复杂度过大。

js 复制代码
var countPalindromicSubsequence = function (s) {
    let set = new Set();
    for (let i = 0; i < s.length; ++i) {
        for (let j = s.length - 1; j > i + 1; --j) {
            if (s[i] === s[j]) {
                for (let k = i + 1; k < j; ++k) {
                    set.add(s[i] + s[k] + s[j]);
                }
            }
        }
    }
    return set.size
};

ac

这个解法时间复杂度就是n,准确来说是26*n,存在常数,即O(n)

寻找每个字符首次出现的位置,还有最后一次出现的位置

如果这两个位置的字符索引不相等,那么就可以形成回文

js 复制代码
var countPalindromicSubsequence = function (s) {
    const firstIndex = new Array(26).fill(-1)
    const lastIndex = new Array(26).fill(-1)
    for(let i = 0; i < s.length; ++i){
        const charCode = s.charCodeAt(i) - 'a'.charCodeAt(0)
        if(firstIndex[charCode] === -1){
            firstIndex[charCode] = i
        }
        lastIndex[charCode] = i
    }
    let sum = 0
    for(let i = 0; i < 26; ++i){
        let first = firstIndex[i]
        let last = lastIndex[i]
        if(first == last) continue
        let charSet = new Set()
        for(let j = first + 1; j < last; ++j){
            charSet.add(s[j])
        }
        sum += charSet.size
    }
    return sum
};
相关推荐
DXM052118 小时前
第9期|从机器学习到深度学习:AI遥感解译的进化逻辑
人工智能·算法·计算机视觉
小蒋学算法18 小时前
算法-阶乘函数后K个零
算法
weixin_3077791318 小时前
智能模拟数据生成平台:生成式AI合成数据技术重塑开发测试效能
人工智能·测试工具·算法·测试用例
Darling噜啦啦18 小时前
JavaScript 数组深度解析:从纯函数到二维数组陷阱,一文吃透前端数据结构核心
前端·javascript·数据结构
万少18 小时前
一封邮件,让我重新打开了搁置半年的鸿蒙应用
前端·javascript·后端
To_OC18 小时前
从一段定时器代码,重新捋清 JS 同步、异步与 Promise
前端·javascript·代码规范
拙慕JULY19 小时前
小程序返回 base64 文件报错
开发语言·javascript·小程序
数据知道19 小时前
字体与排版防线:ClientRects 与系统字体枚举的底层拦截与伪造
javascript·数据采集·指纹浏览器·风控·浏览器指纹
羊羊小栈19 小时前
Uplift营销供应链协同决策系统(基于Uplift因果推断与运筹优化算法)
前端·人工智能·算法·毕业设计·大作业
一壶纱19 小时前
一个用于 UniApp 项目的 Pinia 持久化插件
前端·javascript·vue.js