笔试训练48天:mari和shiny(动态规划 - 线性dp)

链接:https://ac.nowcoder.com/acm/problem/26226

来源:牛客网

题号:NC26226

时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒

空间限制:C/C++/Rust/Pascal 32 M,其他语言64 M

64bit IO Format: %lld

题目描述

mari每天都非常shiny。她的目标是把正能量传达到世界的每个角落!

有一天,她得到了一个仅由小写字母组成的字符串。

她想知道,这个字符串有多少个"shy"的子序列?

(所谓子序列的含义见样例说明)

输入描述:

复制代码
第一行一个正整数n,代表字符串的长度。(1≤n≤300000)
第二行为一个长度为n,仅由小写字母组成的字符串。

输出描述:

复制代码
一个正整数,代表子序列"shy"的数量。

示例1

输入

复制代码
8
sshhyyau

输出:

8

说明:假设字符串下标从1到8。共有(135)(136)(145)(146)(235)(236)(245)(246)八个"shy"子序列。

备注:mari大喊道:"是shiny不是shy!!!"

思路动态规划

①:状态表示:si表示:字符串str中0,i区间内有多少个's';

hi:表示0,i区间有多少个'sh';

yi:表示0,i区间有多少个'shy'

②状态转移方程:

③空间优化

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;
int n;
string str;

int main()
{
    cin>>n>>str;
    long long s=0,h=0,y=0; 
    for(int i=0;i<n;i++)
    {
        char ch=str[i];
        if(ch=='s')s++;
        else if (ch=='h')h+=s;
        else if(ch=='y')y+=h;
    }
    cout<<y<<endl;
    return 0;
}
相关推荐
散峰而望5 小时前
【算法练习】算法练习精选:从 Phone numbers 到 Decrease,覆盖字符串、模拟、图论思维题
数据结构·c++·算法·贪心算法·github·动态规划·图论
人道领域5 小时前
【LeetCode刷题日记】538.把二叉搜索树转换为累加树
java·开发语言·后端·算法·leetcode
并不喜欢吃鱼5 小时前
从零开始 C++----- 十二【C++ 数据结构】map/set 全解析:从使用到红黑树底层模拟实现
开发语言·数据结构·c++
Lsk_Smion5 小时前
力扣实训 _ [33].搜索旋转排序数组 _ [92].翻转链表Ⅱ
java·数据结构·算法
MrZhao4005 小时前
多 Agent 协作与通信:MessageBus 最小实现
算法
Zhang~Ling5 小时前
二叉搜索树(BST)详解:插入、删除、查找与 Key/Value 实战场景
数据结构·c++·算法
8Qi85 小时前
LeetCode 76. 最小覆盖子串(Minimum Window Substring)
数据结构·算法·leetcode·滑动窗口·哈希表
weixin_BYSJ19875 小时前
springboot旅游管理系统04470(附源码+开发文档+部署教程)
java·spring boot·python·算法·django·flask·旅游
Bingorl5 小时前
机器学习之朴素贝叶斯算法
人工智能·算法·机器学习
8Qi86 小时前
LeetCode 209. 长度最小的子数组(Minimum Size Subarray Sum)
java·算法·leetcode·双指针·滑动窗口