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

CodeForces 180C Letter:dp

时间:2018-01-03 11:37:28      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:har   using   ref   scanf   memset   题意   pos   [1]   str   

题目链接:http://codeforces.com/problemset/problem/180/C

题意:

  给你一个字符串s,长度为n。

  让你将这个字符串变成“前面一段都是大写字母,后面一段都是小写字母”的形式。

  (也可以全是大写或全是小写)

  问你最少改动几个字符。

 

题解:

  表示状态:

    dp[i][0/1] = min changes

    表示考虑到第i个字符,s[i]改成了大写(1)或小写(0)时的最小代价

 

  找出答案:

    ans = min(dp[n][0], dp[n][1])

 

  如何转移:

    dp[i][1] = dp[i-1][1] + is_lower(s[i])

    dp[i][0] = min(dp[i-1][0], dp[i-1][1]) + is_upper(s[i])

 

  边界条件:

    dp[i][0] = dp[i][1] = 0

 

AC Code:

 1 #include <iostream>
 2 #include <stdio.h>
 3 #include <string.h>
 4 #define MAX_N 100005
 5 
 6 using namespace std;
 7 
 8 int n;
 9 int dp[MAX_N][2];
10 char s[MAX_N];
11 
12 int is_lower(char c)
13 {
14     return (a<=c && c<=z) ? 1 : 0;
15 }
16 
17 int is_upper(char c)
18 {
19     return (A<=c && c<=Z) ? 1 : 0;
20 }
21 
22 int main()
23 {
24     scanf("%s",s+1);
25     n=strlen(s+1);
26     memset(dp,0,sizeof(dp));
27     for(int i=1;i<=n;i++)
28     {
29         dp[i][1]=dp[i-1][1]+is_lower(s[i]);
30         dp[i][0]=min(dp[i-1][0],dp[i-1][1])+is_upper(s[i]);
31     }
32     cout<<min(dp[n][0],dp[n][1])<<endl;
33 }

 

CodeForces 180C Letter:dp

标签:har   using   ref   scanf   memset   题意   pos   [1]   str   

原文地址:https://www.cnblogs.com/Leohh/p/8182566.html

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