mari和shiny() (多状态dp数组)

mari和shiny

这个用到多状态的线性dp,以往都是一个dp数组,但是这个存在三个dp数组。

cpp 复制代码
#include<bits/stdc++.h>
#include<iostream>
using namespace std;
long long s[300000];
long long h[300000];
long long y[300000];

int main()
{
    int n; cin>>n;
    string str;
    cin>>str;
    s[0]=str[0]=='s'?1:0;
    for(int i=1;i<str.size();i++){
        if(str[i]=='s') s[i]=s[i-1]+1;
        else s[i]=s[i-1];
        
        if(str[i]=='h') h[i]=s[i-1]+h[i-1];
        else h[i]=h[i-1];
        
        if(str[i]=='y') y[i]=h[i-1]+y[i-1];
        else y[i]=y[i-1];
    }
    cout<<y[str.size()-1];
}

空间优化后的代码:

cpp 复制代码
#include<bits/stdc++.h>
#include<iostream>
using namespace std;
long long s;
long long h;
long long y;

int main()
{
    int n; cin>>n;
    string str;
    cin>>str;
    s=str[0]=='s'?1:0;
    for(int i=1;i<str.size();i++){
        if(str[i]=='s') s+=1;
        
        if(str[i]=='h') {h+=s;}
        
        if(str[i]=='y') {y+=h;}
    }
    cout<<y;
}
相关推荐
happymaker06261 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊2 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
八解毒剂3 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录3 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
啦啦啦啦啦zzzz4 小时前
算法总结(二分查找、双指针)
c++·算法
qq_8573058194 小时前
python语法
开发语言·python·算法
DXM05214 小时前
第9期|从机器学习到深度学习:AI遥感解译的进化逻辑
人工智能·算法·计算机视觉
小蒋学算法5 小时前
算法-阶乘函数后K个零
算法
weixin_307779135 小时前
智能模拟数据生成平台:生成式AI合成数据技术重塑开发测试效能
人工智能·测试工具·算法·测试用例
羊羊小栈6 小时前
Uplift营销供应链协同决策系统(基于Uplift因果推断与运筹优化算法)
前端·人工智能·算法·毕业设计·大作业