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;
}
相关推荐
你撅嘴真丑14 小时前
第九章-数字三角形
算法
uesowys14 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder14 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮14 小时前
AI 视觉连载1:像素
算法
智驱力人工智能15 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥16 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风16 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風16 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT0616 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
代码游侠17 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法