力扣 -- 467. 环绕字符串中唯一的子字符串

一、题目

二、解题步骤

下面是用动态规划的思想解决这道题的过程,相信各位小伙伴都能看懂并且掌握这道经典的动规题目滴。

三、参考代码

cpp 复制代码
class Solution {
public:
    int findSubstringInWraproundString(string s) {
        int n=s.size();
        vector<int> dp(n,1);
        int ret=0;
        for(int i=1;i<n;i++)
        {
            if(s[i]==s[i-1]+1||(s[i-1]=='z'&&s[i]=='a'))
            {
                dp[i]+=dp[i-1];
            }
        }

        //去重
        int arr[26]={0};
        for(int i=0;i<n;i++)
        {
            arr[s[i]-'a']=max(dp[i],arr[s[i]-'a']);
        }
        for(const auto& e:arr)
        {
            ret+=e;
        }
        return ret;
    }
};
相关推荐
Tony沈哲几秒前
AI 正在进入本地时代,我开源了一个推理平台—— 支持多模型 / Agent / Workflow 的工程实现
人工智能·算法·llm
黎阳之光几秒前
AI赋能安全新生态 黎阳之光锚定国家政策筑造数智防线
大数据·人工智能·算法·安全·数字孪生
Mem0rin1 分钟前
[Java]异常及其处理
java·开发语言
01二进制代码漫游日记2 分钟前
通讯录(一)
c语言·数据结构·学习
2401_846341655 分钟前
调试技巧与核心转储分析
开发语言·c++·算法
D愿你归来仍是少年6 分钟前
Apache Flink Checkpoint 与 Chandy-Lamport 算法深度解析
算法·flink·apache
爱吃巧克力的程序媛6 分钟前
COM 对象的核心基础知识
c++·qt
奶人五毛拉人一块8 分钟前
C++类和对象的学习-1
c++·对象··构造函数·析构函数·运算符重载
Rooting++8 分钟前
C 指针重点
c语言·开发语言
2301_815482938 分钟前
C++安全编程指南
开发语言·c++·算法