acdream 1201 SuSu's Power dp
题目链接:acdream 1201
给定一个长度为n由AB组成的字符串,AB有不同的操作。遇到A时依据当前状态加1或者减1,遇到B时改变当前状态。(在加1态与减1态之间变化)。现在可以对这个字符串进行m次改动,对同一字符可以重复改动。问最后得到的值的绝对值的最大值为多少。
n,m都较小,因此可以开三维数组来记录状态。
Ma[i][j][k],Mi[i][j][k]分别表示前i个字符串,一共进行过j次改动,当前状态为k的最大与最小值
/******************************************************* File Name: 1201.cpp* Author: kojimai* Creater Time:2014年09月12日 星期五 12时57分12秒
******************************************************/#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<iostream>
using namespace std;
#define FFF 105
char s[FFF];
int Ma[FFF][55][2],Mi[FFF][55][2];//前i天,总共换过j次计划,当前是增是减的最大最小值分别void solve1(int i,int j,int k,int cc)
{//cout<<"i="<<i<<" j="<<j<<" k="<<k<<" val="<<Ma[i][j][k]<<endl;int kk=k,val=Ma[i][j][k];if(cc%2==0){if(s[i]=='A')val+=(kk==1)?1:-1;elsekk=!kk;}else{if(s[i]=='A')kk=!kk;elseval+=(kk==1)?1:-1;}Ma[i+1][j+cc][kk]=max(Ma[i+1][j+cc][kk],val);//cout<<" i+1="<<i+1<<" j+cc="<<j+cc<<" kk="<<kk<<" Ma="<<Ma[i+1][j+cc][kk]<<endl;
}void solve2(int i,int j,int k,int cc)
{//cout<<"i="<<i<<" j="<<j<<" k="<<k<<" val="<<Mi[i][j][k]<<endl;int kk=k,val = Mi[i][j][k];if(cc%2==0){if(s[i]=='A')val+=(kk==1)?1:-1;elsekk=!kk;}else{if(s[i]=='A')kk=!kk;elseval+=(kk==1)?:-1;}Mi[i+1][j+cc][kk]=min(Mi[i+1][j+cc][kk],val);//cout<<" i+1="<<i+1<<" j+cc="<<j+cc<<" kk="<<kk<<" Mi="<<Mi[i+1][j+cc][kk]<<endl;
}int main()
{int n,m,cas=1;while(~scanf("%d",&n)){scanf("%s%d",s,&m);printf("Case #%d: ",cas++);for(int i=0;i<=n;i++){for(int j=0;j<=m;j++){Ma[i][j][0]=-101;Ma[i][j][1]=-101;Mi[i][j][0]=101;Mi[i][j][1]=101;}}Mi[0][0][1]=Ma[0][0][1]=0;for(int i=0;i<n;i++){for(int j=0;j<=m;j++){for(int k = 0; k < 2; k++){for(int cc = 0;cc + j <= m;cc++){if(Ma[i][j][k]>-101)solve1(i,j,k,cc);if(Mi[i][j][k]<101)solve2(i,j,k,cc);}}}}cout<<max(max(Ma[n][m][0],Ma[n][m][1]),max(-Mi[n][m][0],-Mi[n][m][1]))<<endl;}return 0;
}
acdream 1201 SuSu's Power dp相关推荐
- acdream 1409 Musical 状压DP
链接:http://acdream.info/problem? pid=1409 题意:整个国家有n座城市,每座城市有三种粉丝. 第一种一周看一场音乐剧,挑选的音乐剧是已经在周围城市播放上演过的次数最 ...
- hdu 5433(bfs+dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5433 解题思路: dp[i][j][k]表示在(x,y)点,毅力为k时的最小体力.由于每个点可能会走多 ...
- linux安装mysql5.5.52,Linux系统上安装MySQL 5.5prm
RapidXML 试用 近半年来断断续续的封装一些SDK,在兼顾跨平台.易用性和高效率上还要顾及到对外dll的大小问题.由于之前解析SVG文件的用到了一个XML解析库xercesc,这个DLL实在巨大 ...
- 【运动控制】CNC三轴小线段路径规划
CNC三轴小线段路径规划 文章目录 CNC三轴小线段路径规划 一.项目说明 二.具体实现 1.速度规划 2.小线段插补 3.运动学逆解刀轴插补点 4.差分处理得到实际的速度和加速度 5.加速度滑动平均 ...
- 51nod 1201:整数划分 超级好的DP题目
1201 整数划分 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 收藏 关注 将N分为若干个不同整数的和,有多少种不同的划分方式,例如:n = 6,{6} { ...
- acdream 1222 Quantization Problem [dp]
称号:acdream 1222 Quantization Problem 题意:给出一个序列 a ,然后给出一个 n * m 的矩阵,让你从这个矩阵中选出一个序列k,使得sum(abs(ki - ai ...
- Power oj2498/DP/递推
power oj 2498 /递推 2498: 新年礼物 Time Limit: 1000 MS Memory Limit: 65536 KB Total Submit: 12 Accepted: 3 ...
- dp --- acdream原创群赛(16) --- B - Apple
<传送门> B - Apple Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Other ...
- ACdream 1083 有向无环图dp
题目链接:点击打开链接 人民城管爱人民 Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 128000/64000 KB (Java/Othe ...
最新文章
- 技巧:Vim 的纵向编辑模式
- php定义枚举,PHP中Enum(枚举)用法实例详解
- Ubuntu常用基础命令
- 【SpringMVC】SpringMVC基础-SpringMVC项目快速搭建、日志框架为logback
- 前端学习(1644):前端系列实战课程之上移和下移
- matlab中D A1在哪,A1=d(1:15,:);A2=d(16:30,:);A3=
- Java package 与 import
- java webengine_webview – JavaFX 8 WebEngine:如何从java到console.log()从java到System.out?
- 一道打印菱形的面试题
- Java程序与设计11_一些题目
- Java instead of 用法_实例讲解instance of 运算符用法
- No matter how hard it is or no matter how bad it gets, I am going to make it!
- 微博之争,没有硝烟的互联网战争
- Orge配置Debug - 在Mac上利用Homebrew安装指定版本的Cmake
- java泛型数组:Type parameter ‘T‘ cannot be instantiated directly
- imx6ull 以太网
- ffmpeg之av_read_frame
- 网络及路由器故障诊断基础知识
- Linux如何查看当前Ubuntu系统的版本
- ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map