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

相关文章

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

springboot报错Invalid bound statement (not found)的解决

《springboot报错Invalidboundstatement(notfound)的解决》本文主要介绍了springboot报错Invalidboundstatement(not... 目录一. 问题描述二.解决问题三. 添加配置项 四.其他的解决方案4.1 Mapper 接口与 XML 文件不匹配

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作