https://vjudge.net/problem/CodeForces-1278C

题意:有2n瓶果酱,中间有一个楼梯隔开,从中间往左或右两边清空果酱,使得两种果酱的数量相等,最少要清空多少瓶

思路:第一眼看到并没有什么思路,想用果酱数量的前缀和,但不知道怎么运用,看到一篇博客,把数字2改为-1这几个字眼,恍然大悟。


例如第一组数据

原数据 1,1,1,2,2,         1,2,1,2,1,1,2

变为   1,1,1,-1,-1,1,   -1,1,-1,1,1,-1

前缀和 ,2,3,2,,2,     0,1,0,1,0,-1

因为清除果酱只能从中间的楼梯向两边扩展,所以左边的前缀和是→累加的,右边的前缀和是←累加的也叫后缀和吧。正负分别表示某种果酱多出的数量,相加相等则表示数量相等。如上的红色字体位置,二者之间的果酱都需要清除掉,共6瓶。为了使清除的果酱数量尽可能少,相同的前后缀和,左边前缀和尽量往右靠,右边后缀和尽量往左靠。

又如另一组数据

原数据 1,0,0,      1,0,0

变为   1,-1,-1,    1,-1,-1

前缀和 ,0,-1,    -1,-2,-1

显然去掉左边2瓶就是答案。

选择红色位置用aid数组和bid数组,这两个数组起到指示下标的作用。

第三组数据的应对方法详看代码。

第四种数组1,2,  1,1或者1,1,  2,1之类的,需要对0做出处理。在这个数据上wa很多次。详看代码。

import java.util.Arrays;
import java.util.Scanner; public class Main { public static void main(String[] args) {
Scanner scan=new Scanner(System.in);
int n,x; int t=scan.nextInt();
while(t!=0) {
int p=100000;
int [] a=new int[100005];//左边果酱前缀和 →
int [] b=new int[100005];//右边果酱后缀和 ←
int [] aid=new int[200005];
int [] bid=new int[200005];
//前缀和的数字下标,aid[2]=5表示a前缀数组内容为2的在前缀和数组下标为5的位置
t--;
n=scan.nextInt();
aid[p]=0;
for(int i=1;i<=n;i++) {//从左到右输入,直接计算前缀和
x=scan.nextInt();
if(x==1)
a[i]=a[i-1]+1;
else
a[i]=a[i-1]-1; int idx=a[i]+p;//防止遇到负数导致数组越界
aid[ idx ]=i;//前缀和尽量往右靠,i越来越大
} for(int i=1;i<=n;i++) {//从左到右输入
x=scan.nextInt();
if(x!=1)
x=-1;
b[i]=x;
}
bid[p]=n+1;
for(int i=n;i>=1;i--) {//从右往左计算后缀和
b[i]+=b[i+1]; int idx=b[i]+p;
bid[idx]=i;//后缀和尽量往左靠,i越来越小
} int ans=2*n;//最多把全部果酱拿走,应付第3组数据
for(int i=-n;i<=n;i++) {
if( (aid[p+i]!=0 && bid[p-i]!=0) || (i==0))
ans=Math.min(ans,n-aid[p+i]+bid[p-i]-1);
}
System.out.println(ans);
}
} }

CF1278C-Berry Jam-(前缀和)的更多相关文章

  1. codeforcesC - Berry Jam(折半枚举+1-1序列前后缀和)

    Educational Codeforces Round 78 (Rated for Div. 2) C - Berry Jam C. Berry Jam time limit per test 2 ...

  2. Educational Codeforces Round 78 (Rated for Div. 2) C. Berry Jam

    链接: https://codeforces.com/contest/1278/problem/C 题意: Karlsson has recently discovered a huge stock ...

  3. Berry Jam (前缀和)cf教育场

    距离上一篇博客又2个月了 寻思着该除除草了 教育场是真的好难 可能是因为我还是只菜鸡 哭唧唧 先说下题意:有2*n罐果酱,草莓和蓝莓,梯子在中间从梯子那开始往两边吃(可以一会左一会右),问最少吃多少果 ...

  4. Educational Codeforces Round 78 (Rated for Div. 2) C - Berry Jam(前缀和)

  5. CF 1278C Berry Jam 题解

    Forewords 说实话我是被图吸引进来的23333,图画的真的挺好看. 题意 你从一个梯子下到地下室,梯子左右两边各有 \(n\) 瓶果酱排成一排,果酱口味为草莓味或蓝莓味,你每次只能吃你左边或右 ...

  6. Berry Jam codeforces 1278C

    题目大意: 有两种类型的果酱,一个梯子,从中间开始吃,可以吃左边的,也可以吃右边的,最终要使两种类型的果酱的数量想等 题解: 思路对了,但是没考虑完. 对梯子的左侧的果酱I我们用两个数组记录其从1到i ...

  7. 2021record

    2021-10-14 P2577 [ZJOI2004]午餐 2021-10-13 CF815C Karen and Supermarket(小小紫题,可笑可笑) P6748 『MdOI R3』Fall ...

  8. Educational Codeforces Round 78 (Rated for Div. 2) 题解

    Shuffle Hashing A and B Berry Jam Segment Tree Tests for problem D Cards Shuffle Hashing \[ Time Lim ...

  9. 【cf比赛记录】Educational Codeforces Round 78 (Rated for Div. 2)

    比赛传送门 A. Shuffle Hashing 题意:加密字符串.可以把字符串的字母打乱后再从前面以及后面接上字符串.问加密后的字符串是否符合加密规则. 题解:字符串的长度很短,直接暴力搜索所有情况 ...

  10. HDU1671——前缀树的一点感触

    题目http://acm.hdu.edu.cn/showproblem.php?pid=1671 题目本身不难,一棵前缀树OK,但是前两次提交都没有成功. 第一次Memory Limit Exceed ...

随机推荐

  1. Java解析XML字符串,取出其中<aaaa><![CDATA[(XXX)]]></aaa>里面的XXX值,也可以使用xml解析的其他方式,这是最简单的字符串解析

    直接贴一段业务代码,这段代码是解析请求返回的xml格式字符串,为了取出其中的值便于下一步的使用. @RequestMapping(value="/search",produces ...

  2. acwing 652. 切蛋糕

    题目地址 今天是小Z的生日,同学们为他带来了一块蛋糕. 这块蛋糕是一个长方体,被用不同色彩分成了N个相同的小块,每小块都有对应的幸运值. 小Z作为寿星,自然希望吃到的第一块蛋糕的幸运值总和最大,但小Z ...

  3. LeetCode 1244. 力扣排行榜

    地址 https://www.acwing.com/solution/LeetCode/content/5765/ 题目描述新一轮的「力扣杯」编程大赛即将启动,为了动态显示参赛者的得分数据,需要设计一 ...

  4. LeetCode 5275. 找出井字棋的获胜者 Find Winner on a Tic Tac Toe Game

    地址 https://www.acwing.com/solution/LeetCode/content/6670/ 题目描述A 和 B 在一个 3 x 3 的网格上玩井字棋. 井字棋游戏的规则如下: ...

  5. [C5W3] Sequence Models - Sequence models & Attention mechanism

    第三周 序列模型和注意力机制(Sequence models & Attention mechanism) 基础模型(Basic Models) 在这一周,你将会学习 seq2seq(sequ ...

  6. 防止ssh暴力破解的小工具denyhosts

    DenyHosts 简介 DenyHosts 是 Python 语言写的一个程序软件,运行于 Linux 上预防 SSH 暴力破解的,它会分析 sshd 的日志文件(/var/log/secure), ...

  7. 【转】Ubuntu 16 安装 python 依赖出现 error: command 'i686-linux-gnu-gcc' failed with exit status 1

    问题 在 Ubuntu 下安装 python 依赖的时候出现以下错误 build/temp.linux-i686-3.5/_openssl.c:498:30: fatal error: openssl ...

  8. Core源码(四)IEnumerable

    首先我们去core的源码中去找IEnumerable发现并没有,如下 Core中应该是直接使用.net中对IEnumerable的定义 自己实现迭代器 迭代器是通过IEnumerable和IEnume ...

  9. C# 同步转异步 AutoResetEvent

    当我们的程序运行时,调用了一段异步的逻辑A,这段异步的逻辑无法转化为同步(如动画.下载进度等) 而,我们又需要等待异步逻辑A处理完成,然后再执行其它逻辑B. AutoResetEvent 同步转异步 ...

  10. centos下搭建python双版本环境

    目录 centos下搭建python双版本环境 一.安装python3 1.理清自带python位置 2.更新用于下载编译python3的相关包 3.安装pip 4.用pip安装wget 5.用wge ...