首页 > 代码库 > HDU-2577 How to Type DP
HDU-2577 How to Type DP
字符输入问题,刚开始没有考虑到shift+字符输入和当前大小写锁定状态相反状态字符只需要两步的问题。
状态转移方程:dp1[i]表示输入完第i个字符后为大写状态需要的步数 dp2[i]表示输入完第i个字符后为小写状态所需要的步数
如果第i个字符为小写:
dp1[i]=min(dp1[i-1]+2,dp2[i-1]+2);
dp2[i]=min(dp1[i-1]+2,dp2[i-1]+1);
如果第i个字符为大写:
dp1[i]=min(dp1[i-1]+1,dp2[i-1]+2);
dp2[i]=min(dp1[i-1]+2,dp2[i-1]+2);
#include <iostream> #include <cstdio> #include <cmath> #include <queue> #include <vector> #include <cstring> #include <algorithm> using namespace std; char s[111]; int dp1[111]; int dp2[111]; int main() { int t; scanf("%d",&t); while(t--) { scanf("%s",s); int len=strlen(s); if(s[0]>='A'&&s[0]<='Z') { dp1[0]=2; dp2[0]=2; } else { dp1[0]=2; dp2[0]=1; } for(int i=1;i<len;i++) { if(s[i]>='A'&&s[i]<='Z') { dp1[i]=min(dp1[i-1]+1,dp2[i-1]+2); dp2[i]=min(dp1[i-1]+2,dp2[i-1]+2); } else { dp1[i]=min(dp1[i-1]+2,dp2[i-1]+2); dp2[i]=min(dp1[i-1]+2,dp2[i-1]+1); } } cout<<dp2[len-1]<<endl; } return 0; }
HDU-2577 How to Type DP
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。