力扣 -- 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;
    }
};
相关推荐
liulilittle2 分钟前
SQLite3增删改查(C
c语言·开发语言·数据库·c++·sqlite
左左右右左右摇晃2 分钟前
ConcurrentHashMap 设计原理笔记
java·开发语言·笔记
CVer儿30 分钟前
c++的移动语义
c++
We་ct30 分钟前
LeetCode 4. 寻找两个正序数组的中位数:二分优化思路详解
前端·数据结构·算法·leetcode·typescript·二分
于先生吖34 分钟前
国际语言适配拼车系统 JAVA 后端源码 + 同城顺风车功能全解析
java·开发语言
ID_1800790547341 分钟前
超详细:Python 调用淘宝商品详情 API 完整教程
开发语言·python
逻辑君1 小时前
Research in Brain-inspired Computing [7]-带关节小人(3个)推箱的类意识报告
c++·人工智能·神经网络·机器学习
小恶魔巴巴塔1 小时前
C语言避免头文件循环
c语言·开发语言
西西学代码1 小时前
Flutter---构造函数
开发语言·javascript·flutter
仍然.1 小时前
算法题目---位运算
算法