A5(用状态机模型解决字符串问题

2024-02-26 18:08

本文主要是介绍A5(用状态机模型解决字符串问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
在这里插入图片描述
明明状态2是可以由状态4转移过来的(也就是说AAA5再遇到5的时候会变成AAA55,此时不得不转移这个非法状态了,那么如果改5为A的话,就会回到状态4,如果随便改一个A为5的话,就会回到状态2(AA555),可是为什么我加入这个状态2的转移入口的时候反而错了呢?!奇怪了奇怪了。

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
string s;
int t,n;
int dp[1000][5];
int minn(int a,int b,int c){return min(a, min(b,c));
}
int main(){cin>>t;while(t--){memset(dp,0x3f,sizeof dp);cin>>s;n=s.length();//cout<<"n="<<n<<endl;if(n<5){cout<<"0"<<endl;continue;}//入口for(int i=1;i<=4;i++)dp[0][i]=0;if(s[0]=='A')dp[0][0]=1;else dp[0][0]=0;for(int i=1;i<n;i++){if(s[i]=='A'){dp[i][0]=dp[i-1][0]+1;dp[i][1]=min(dp[i-1][1]+1,dp[i-1][0]);dp[i][2]=min(dp[i-1][2]+1,dp[i-1][1]);dp[i][3]=dp[i-1][3];//这2个状态是为了不脱节状态内的转移,上面3个是状态间的转移dp[i][4]=dp[i-1][4];}if(s[i]=='5'){dp[i][0]=dp[i-1][0];dp[i][1]=dp[i-1][1];dp[i][2]=dp[i-1][2];//这三个状态是为了不脱节状态内的转移,下面两个是状态间的转移//dp[i][2]=min(dp[i-1][2],dp[i-1][4]+1);dp[i][3]=min(dp[i-1][3]+1,dp[i-1][2]);dp[i][4]=min(dp[i-1][4]+1,dp[i-1][3]);}//cout<<"dp["<<i<<"][0 1 2]="<<dp[i][0]<<"--"<<dp[i][1]<<"--"<<dp[i][2]<<endl;//cout<<"dp["<<i<<"][3 4]="<<dp[i][3]<<"--"<<dp[i][4]<<endl;}//出口int min1=min(dp[n-1][4],dp[n-1][1]);int min2=min(dp[n-1][2],dp[n-1][3]);cout<<min(min1,min2)<<endl;}
}

上面是加注释版的代码
下面是删减版代码(就是想看看code能短到什么长度hhh

#include <bits/stdc++.h>
using namespace std;
string s;
int t,n;
int dp[1000][5];
int main(){cin>>t;while(t--){memset(dp,0x3f,sizeof dp);cin>>s;n=s.length();for(int i=1;i<=4;i++)dp[0][i]=0;if(s[0]=='A')dp[0][0]=1;else dp[0][0]=0;for(int i=1;i<n;i++){if(s[i]=='A'){dp[i][0]=dp[i-1][0]+1;dp[i][1]=min(dp[i-1][1]+1,dp[i-1][0]);dp[i][2]=min(dp[i-1][2]+1,dp[i-1][1]);dp[i][3]=dp[i-1][3];dp[i][4]=dp[i-1][4];}if(s[i]=='5'){dp[i][0]=dp[i-1][0];dp[i][1]=dp[i-1][1];dp[i][2]=dp[i-1][2];dp[i][3]=min(dp[i-1][3]+1,dp[i-1][2]);dp[i][4]=min(dp[i-1][4]+1,dp[i-1][3]);}}int min1=min(dp[n-1][4],dp[n-1][1]);int min2=min(dp[n-1][2],dp[n-1][3]);cout<<min(min1,min2)<<endl;}
}

这篇关于A5(用状态机模型解决字符串问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/749708

相关文章

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

Redis 热 key 和大 key 问题小结

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、什么是 Redis 热 key?热 key(Hot Key)定义: 热 key 常见表现:热 key 的风险:二、

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊

Spring Boot中JSON数值溢出问题从报错到优雅解决办法

《SpringBoot中JSON数值溢出问题从报错到优雅解决办法》:本文主要介绍SpringBoot中JSON数值溢出问题从报错到优雅的解决办法,通过修改字段类型为Long、添加全局异常处理和... 目录一、问题背景:为什么我的接口突然报错了?二、为什么会发生这个错误?1. Java 数据类型的“容量”限制

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

最详细安装 PostgreSQL方法及常见问题解决

《最详细安装PostgreSQL方法及常见问题解决》:本文主要介绍最详细安装PostgreSQL方法及常见问题解决,介绍了在Windows系统上安装PostgreSQL及Linux系统上安装Po... 目录一、在 Windows 系统上安装 PostgreSQL1. 下载 PostgreSQL 安装包2.