力扣 -- 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;
    }
};
相关推荐
立志成为大牛的小牛12 分钟前
数据结构——五十五、散列查找的性能分析(线性探测法)(王道408)
数据结构·程序人生·考研·算法
咕噜签名-铁蛋13 分钟前
云服务器远程连接失败?
开发语言·php
~无忧花开~37 分钟前
Vue二级弹窗关闭错误解决指南
开发语言·前端·javascript·vue.js
老华带你飞41 分钟前
在线教育|基于springboot + vue在线教育系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端
神也佑我橙橙1 小时前
Thrift 简单介绍
算法
simon_skywalker1 小时前
线性代数及其应用习题答案(中文版)第二章 矩阵代数 2.1 矩阵运算(2)
线性代数·算法·矩阵
jiayong231 小时前
数据结构时间复杂度完全解析
数据结构
REDcker1 小时前
JS 与 C++ 语言绑定技术详解
开发语言·javascript·c++
June`1 小时前
C++11新特性全面解析(三):智能指针与死锁
开发语言·c++
认真敲代码的小火龙1 小时前
【JAVA项目】基于JAVA的医院管理系统
java·开发语言·课程设计