[POI2013]BAJ-Bytecomputer
题目描述
A sequence of  integers
 integers  from the set
 from the set  is given.
 is given.
The bytecomputer is a device that allows the following operation on the sequence:
incrementing  by
 by  for any
 for any  .
.
There is no limit on the range of integers the bytecomputer can store, i.e., each  can (in principle) have arbitrarily small or large value.
 can (in principle) have arbitrarily small or large value.
Program the bytecomputer so that it transforms the input sequence into a non-decreasing sequence (i.e., such that  ) with the minimum number of operations.
) with the minimum number of operations.
给一个只包含-1,0,1的数列,每次操作可以让a[i]+=a[i-1],求最少操作次数使得序列单调不降
输入输出格式
输入格式:
The first line of the standard input holds a single integer  (
 ( ), the number of elements in the (bytecomputer's) input sequence.
), the number of elements in the (bytecomputer's) input sequence.
The second line contains  integers
 integers  (
 ( ) that are the successive elements of the (bytecomputer's) input sequence, separated by single spaces.
) that are the successive elements of the (bytecomputer's) input sequence, separated by single spaces.
In tests worth 24% of the total points it holds that  , and in tests worth 48% of the total points it holds that
, and in tests worth 48% of the total points it holds that  .
.
输出格式:
The first and only line of the standard output should give one integer, the minimum number of operations the bytecomputer has to perform to make its input sequence non-decreasing, of the single word BRAK (Polish for none) if obtaining such a sequence is impossible.
Solution
DP。
比较明显的是我们最多也只需要把一个数位加到1,最少减到-1就可以了。用$f[i][j],i\in Z,1\le i \le n,j\in Z,0 \le j \le 2 $表示第i个数的第j状态需要怎么转移过来,然后暴力枚举之前的可能情况,然后直接根据当前的情况进行转移就可以了。
Code
#pragma comment(linker, "/STACK:1024000000,1024000000")
#include <iostream>
#include <cstdlib>
#include <cmath>
#include <string>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <queue>
#include <set>
#include <map>
#define re register
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
#define ms(arr) memset(arr, 0, sizeof(arr))
const int inf = 0x3f3f3f3f;
int f[1000001][3],n,m,a[1000001],ans;
inline int read()
{
    int x=0,c=1;
    char ch=' ';
    while((ch>'9'||ch<'0')&&ch!='-')ch=getchar();
    while(ch=='-') c*=-1,ch=getchar();
    while(ch<='9'&&ch>='0')x=x*10+ch-'0',ch=getchar();
    return x*c;
}
int main()
{
    //freopen("date.in","r",stdin);
    n=read();
    memset(f,126,sizeof(f));
    for(re int i=1;i<=n;i++)
    	a[i]=read();
    f[1][a[1]+1]=0;
    for(re int i=2;i<=n;i++){
    	if(a[i]==-1){
    		f[i][0]=f[i-1][0];
    		f[i][2]=f[i-1][2]+2;
    	}else if(a[i]==0){
    		f[i][0]=f[i-1][0]+1;
    		f[i][1]=min(f[i-1][0],f[i-1][1]);
    		f[i][2]=f[i-1][2]+1;
    	}else{
    		f[i][0]=f[i-1][0]+2;
    		f[i][1]=f[i-1][0]+1;
    		f[i][2]=min(min(f[i-1][0],f[i-1][1]),f[i-1][2]);
    	}
    }
    ans=min(min(f[n][0],f[n][1]),f[n][2]);
    if(ans>200000000) cout<<"BRAK";
    else cout<<ans;
    return 0;
}
[POI2013]BAJ-Bytecomputer的更多相关文章
- 【bzoj3427】Poi2013 Bytecomputer  dp
		题目描述 A sequence of N integers I1,I2…In from the set {-1,0,1} is given. The bytecomputer is a device ... 
- 【BZOJ】3427: Poi2013 Bytecomputer
		题意: 给定一个长度为\(n\)的\(\{-1, 0, 1\}\)组成的序列,你可以进行\(x_i=x_i+x_{i-1}\)这样的操作,求最少操作次数使其变成不降序列.(\(n \le 100000 ... 
- BZOJ3427 Poi2013 Bytecomputer
		可以YY一下嘛= = 最后一定是-1, -1, ..., -1, 0, 0, ... 0, 1, 1, ..., 1的一个数列 于是f[i][j]表示到了第i个数,新数列的第j项为-1 or 0 or ... 
- BZOJ3427 Poi2013 Bytecomputer  【dp】
		题目链接 BZOJ3427 题解 容易发现最终序列一定是\(\{-1,0,1\}\)组成的 因为如果有一个位置不是,那么这个位置一定大于\(1\),那么上一个位置一定为\(1\),所以该位置一定加到过 ... 
- POI2013 Bytecomputer
		题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3427 可以证明最终序列为-1...0....1 因为首先如果 a(i-1) 为-1或0,执行操 ... 
- POI2013题解
		POI2013题解 只做了BZ上有的\(13\)道题. 就这样还扔了两道神仙构造和一道计算几何题.所以只剩下十道题了. [BZOJ3414][Poi2013]Inspector 肯定是先二分答案,然后 ... 
- bzoj 1138: [POI2009]Baj 最短回文路 dp优化
		1138: [POI2009]Baj 最短回文路 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 161 Solved: 48[Submit][Sta ... 
- [POI2013]Łuk triumfalny
		[POI2013]Łuk triumfalny 题目大意: 一棵\(n(n\le3\times10^5)\)个结点的树,一开始\(1\)号结点为黑色.\(A\)与\(B\)进行游戏,每次\(B\)能选 ... 
- [POI2013]Polaryzacja
		[POI2013]Polaryzacja 题目大意: 给定一棵\(n(n\le250000)\)个点的树,可以对每条边定向成一个有向图,这张有向图的可达点对数为树上有路径从\(u\)到达\(v\)的点 ... 
- [POI2013]Taksówki
		[POI2013]Taksówki 题目大意: ABC三地在同一条直线上,AC相距\(m(m\le10^{18})\)米,AB相距\(d\),B在AC之间.总共有\(n(n\le5\times10^5 ... 
随机推荐
- 再论IBatisNet + Castle进行项目的开发
			随着项目的进展,Castle和IBatisNet给我的惊喜更多.Com+很重,不需要分布式的中小项目慎用,NHibernate虽好,NHibernate的2005-9-20发布了最新版本1.0-rc1 ... 
- BF算法 + KMP算法
			准备: 字符串比大小:比的就是字符串里每个字符的ASCII码的大小.(其实这样的比较没有多大的意义,我们关心的是字符串是否相等,即匹配等) 字符串的存储结构:同线性表(顺序存储+链式存储) 顺序存储结 ... 
- UVALive 6560 The Urge to Merge
			题目链接:传送门 题目大意:有一个 3*n 的矩阵,每个格子里有一个数,你可以选择相邻的两个格子合并成一个,并且权值变为两数乘积,若一个数未合并,权值变为0,求最后权值总和最大值. 题目思路:以 2^ ... 
- iOS 下载
			#import "ViewController.h" @interface ViewController () @property (strong, nonatomic) NSMu ... 
- 如何设置,使IntelliJ IDEA智能提示忽略大小写
- Flask(1)- 主流web框架、初识flask
			一.Python 现阶段三大主流Web框架 Django.Tornado.Flask 对比 Django 主要特点是大而全,集成了很多组件(例如Models.Admin.Form等等), 不管你用得到 ... 
- windows下的Mysql安装与基本使用(zip)
			一.安装过程 Mysql社区版下载地址:http://dev.mysql.com/downloads/mysql/ --注意,已管理员身份运行cmd.exe,很重要!!目录在,c:\windows\s ... 
- mysql 建立表之间关系 一对一 练习2
			创建db5数据库 create database db5 charset=utf8; use db5; 例二:一个管理员唯一对应一个用户 用户表: id user password 1 egon xx ... 
- [今日干货]一个吸粉效果也不错的APP
			最近陌陌被封很厉害,今天给大家分享一个吸粉效果也不错的APP——悦跑圈,日吸几百粉没问题~ 1.首先下载APP悦跑圈,用手机号码注册. 2.改写资料和头像,最好用一个女性头像,真实点的,不是网图,增加 ... 
- New Moto X 2014 全版本官方解锁Bootloader图文教程
			]秒后松开,手机就会进入fastboot模式. 如下图: <ignore_js_op> 接下来,手机连接电脑,打开刚刚的fastboot工具里面的命令提示符: <ignore_js_ ... 
