cf706C(dp)
题目链接:http://codeforces.com/problemset/problem/706/C
题意:给出n个字符串,反转第 i 个字符串需要花费 ai,问通过反转操作将n个字符串变成升序排列,最小花费是多少,不能使其升序排列的话输出-1;
思路:dp
不难想到只有当前字符串的前一个字符串会对当前字符串产生直接影响,而每个字符串都只有反转和不反转两种状态;
我们可以用dp[i][0]表示第i个字符串不反转的情况从第0到第i个字符变成升序的需要的最小花费,dp[i][1]表示第i个字符串反转的情况从第0到第i个字符变成升序的需要的最小花费;
对于第 i 个字符串我们可以选择反转或者不反转,对于每种选择又会产生三中可能, 我们用str1, str2存储当前字符串和其反转字符串,s, rs存储前一个字符串和对应反转字符串,
那么有:
当前字符串不反转:
str1>=s&&str1>=rs
str1>=s&&str1<rs
str1>=rs&&str1<s
当前字符串反转:
str2>=s&&str2>=rs
str2>=s&&str2<rs
str2>=rs&&str2<s
想清楚了这些状态也就不难写出状态转移方程式了:
if(str1>=s&&str1>=rs){
dp[i][]=min(dp[i-][], dp[i-][]);
}else if(str1>=s){
dp[i][]=dp[i-][];
}else if(str1>=rs){
dp[i][]=dp[i-][];
}else{
ok1=false; //不反转比s, rs都要小
}
//若当前字符串反转
if(str2>=s&&str2>=rs){
dp[i][]=min(dp[i-][], dp[i-][])+a[i];
}else if(str2>=s){
dp[i][]=dp[i-][]+a[i];
}else if(str2>=rs){
dp[i][]=dp[i-][]+a[i];
}else{
ok2=false;//反转比s, rs都要小
}
代码:
#include <bits/stdc++.h>
#define ll long long
using namespace std; const int MAXN=1e5+;
const ll inf=0x3f3f3f3f3f3f3f3f;
ll dp[MAXN][], a[MAXN];//a数组存储花费
//dp[i][0]表示第i个字符串不反转的情况从第0到第i个字符变成升序的需要的最小花费,dp[i][1]表示第i个字符串反转的情况从第0到第i个字符变成升序的需要的最小花费 int main(void){
ios::sync_with_stdio(false), cin.tie(), cout.tie();
int n;
cin >> n;
for(int i=; i<n; i++){
cin >> a[i];
}
bool flag=true;
string s, rs, str1, str2;
cin >> s;
rs=s;
reverse(rs.begin(), rs.end());
dp[][]+=a[];
for(int i=; i<n; i++){
cin >> str1;
str2=str1;
reverse(str2.begin(), str2.end());
if(flag){
bool ok1=true, ok2=true;
//**若当前字符串不反转
if(str1>=s&&str1>=rs){
dp[i][]=min(dp[i-][], dp[i-][]);
}else if(str1>=s){
dp[i][]=dp[i-][];
}else if(str1>=rs){
dp[i][]=dp[i-][];
}else{
ok1=false; //不反转比s, rs都要小
}
//若当前字符串反转
if(str2>=s&&str2>=rs){
dp[i][]=min(dp[i-][], dp[i-][])+a[i];
}else if(str2>=s){
dp[i][]=dp[i-][]+a[i];
}else if(str2>=rs){
dp[i][]=dp[i-][]+a[i];
}else{
ok2=false;//反转比s, rs都要小
}
if(!ok1&&!ok2){
flag=false;
}else if(!ok1&&ok2){
dp[i][]=inf;
}else if(ok1&&!ok2){
dp[i][]=inf;
}
}
s=str1;
rs=str2;
}
ll ans=min(dp[n-][], dp[n-][]);
if(!flag||ans>=inf){
cout << - << endl;
}else{
cout << ans << endl;
}
return ;
}
cf706C(dp)的更多相关文章
- BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 4142 Solved: 1964[Submit][Statu ...
- 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...
- AEAI DP V3.7.0 发布,开源综合应用开发平台
1 升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...
- AEAI DP V3.6.0 升级说明,开源综合应用开发平台
AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...
- BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]
1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4026 Solved: 1473[Submit] ...
- [斜率优化DP]【学习笔记】【更新中】
参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...
- BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]
1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 9812 Solved: 3978[Submit][St ...
- px、dp和sp,这些单位有什么区别?
DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...
- android px转换为dip/dp
/** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...
随机推荐
- vue --- axios , vuex
一 . 内容回顾 1.webpack(前端中工作,项目上线之前对整个前端项目优化) - entry:整个项目的程序入口(main.js或index.js): - output:输出的出口: - loa ...
- 《高性能Javascript》 Summary(一)
第一章.加载和执行 Loading & Execution 原因:Javascript 的执行导致页面渲染中止等待. 解决: 将script放在页面底部,紧靠body 闭合标签之前,保证页面在 ...
- Android环境下通过C框架层控制WIFI【转】
本文转载自:https://blog.csdn.net/edw200/article/details/52192631 本人是从事Linux嵌入式开发的,安卓wifi控制在安卓JAVA层已经做得非常成 ...
- (2)struts2配置祥解
struts工作流程 反射 : 1.构造对象使用构造器 //类似为Servlet public class AddAction { public AddAction(){ System.out.pri ...
- matlab之flipud()函数
此函数实现矩阵的上下翻转.fliplw()实现左右旋转. 举例: a =[1 2;3 4;5 6] flipud(a)的结果: 5 6 3 4 1 2 fliplr(a)的结果: 2 1 4 3 6 ...
- iOS审核总被拒?腾讯教你提升iOS审核通过率!
作者:Jamie,腾讯开发工程师,在iOS预审和ASO优化领域从事专项测试相关工作,为腾讯游戏近100个产品提供专项服务. 商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. WeTest ...
- windowService中使用多线程
windowService中使用多线程 代码 using System;using System.Collections.Generic;using System.Linq;using System. ...
- VC Q&A (原创)
Q1:External Dependencies有什么作用? A1:(网友答复:)External Dependencies是说你没有把这个文件加入到这个工程中,但是需要这个文件的支持.当然有时是 ...
- codeforces 706B B. Interesting drink(二分)
题目链接: B. Interesting drink 题意: 给出第i个商店的价钱为x[i],现在询问mi能在多少个地方买酒; 思路: sort后再二分; AC代码: #include <ios ...
- poj-1986 Distance Queries(lca+ST+dfs)
题目链接: Distance Queries Time Limit: 2000MS Memory Limit: 30000K Total Submissions: 11531 Accepted ...