码迷,mamicode.com
首页 > 其他好文 > 详细

HDU-2577 How to Type DP

时间:2014-10-19 18:39:15      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:acm   hdu   

字符输入问题,刚开始没有考虑到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

标签:acm   hdu   

原文地址:http://blog.csdn.net/q295657451/article/details/40264595

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!