蓝桥杯的一道题:灵能传输 https://www.acwing.com/problem/content/description/1250/

首先是简化操作,将原数组转化为前缀和数组(下标都是从1开始),一次灵能传输对原数组涉及三个数(a[i-1],a[i],a[i+1])的操作,而且操作比较麻烦,但是如果转化成前缀和数组后等价于(s[i-1]与s[i])交换位置。

原来的目标是求a[i]绝对值最小值,那么现在的目标变为求s[i]-s[i-1]的绝对值最大值,其中设计的数有s[0~n]

2.由于对数组可以任意交换位置,经过简单的思考可以得知如果序列单调(后面就说成单增了),那么即为所求,那么对s数组排序即可。

但是存在一个问题,即s[0],s[n]参与最后求s[i]-s[i-1]的绝对值最大值的计算,但是由于题意可知s[0],s[n]是无法移动的,因此在此情况下怎么排序呢?

上面两种方式(这里假设s0 是小于sn的(如果是大于,swap一下就是一样的))

右边更优秀,为何?

简单理解就是由于s0比sn更小,因此左边s0到最大值比右边sn到最大值明显差值会小一些。

现在问题变为如何排成右边这种序列?

答案以代码呈现:

if(s0 > sn) swap(s0, sn);

        sort(s, s + n + 1);

        for(int i = 0; i <= n; i ++ )
if(s[i] == s0)
{
s0 = i;
break;
} for(int i = n; i >= 0; i -- )
if(s[i] == sn)
{
sn = i;
break;
} memset(st, 0,sizeof st);
int l = 0 ,r = n; for(int i = s0; i >= 0; i -= 2)
{
a[l ++ ] = s[i];
st[i] = true;
} for(int i = sn; i <= n; i += 2)
{
a[r -- ] = s[i];
st[i] = true;
} for(int i = 0; i <= n; i ++ )
if(!st[i]) a[l ++ ] = s[i]; LL res = 0; for(int i = 1; i <= n; i ++ ) res = max(res, abs(a[i] - a[i - 1]));

核心就是隔一个一取,为何是隔一个,反证法想一想不隔,或者隔两个是个什么情况(反过来的时候是隔两个,就比一次隔一个反过来也是隔一个大了)可以参见y总视频。

详细分析见:

java代码实现:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays; /**
*
*/
public class Main {
static int N=300000+5;
//细节:由于涉及前缀和再加上数据范围,因此需要long
static long[] a=new long[N];
static long[] sum=new long[N];
static int n;
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String[] line = reader.readLine().split(" ");
int t=Integer.parseInt(line[0]);
while (t--!=0) {
Arrays.fill(a, 0);
Arrays.fill(sum, 0);
line=reader.readLine().split(" ");
n=Integer.parseInt(line[0]);
line=reader.readLine().split(" ");
for (int i = 1; i <= n; i++) {
a[i]=Integer.parseInt(line[i-1]);
}
start();
} }
private static void start() {
for (int i = 1; i <= n; i++) {
sum[i]=sum[i-1]+a[i];
}
//s0开始是记数,后面就是记下标了
long s0=sum[0],sn=sum[n];
if (s0>sn) {
long t=s0;
s0=sn;
sn=t;
}
Arrays.sort(sum,0,n+1);
for (int i = 0; i <= n; i++) {
if (sum[i]==s0) {
s0=i;
//第一次遇到就break,否则赋值之后万一又意外相等了
break;
}
}
for (int i = n; i >= 0; i--) {
if (sum[i]==sn) {
sn=i;
break;
}
}
boolean[] st=new boolean[N];
int l=0,r=n;
//a[i]在计算前缀和之后就没有使用了,因此这里再次使用a来减小数据空间
//跳着读取
for (int i = (int)s0; i >= 0; i-=2) {
a[l++]=sum[i];
st[i]=true;
}
for(int i=(int)sn;i<=n;i+=2){
a[r--]=sum[i];
st[i]=true;
}
for (int i = 0; i <= n; i++) {
if (!st[i]) {
a[l++]=sum[i];
}
} long res=0L;
for (int i = 1; i <= n; i++) {
res=Math.max(res,Math.abs( a[i]-a[i-1]));
}
System.out.println(res);
}
}

AcWing 1248. 灵能传输 蓝桥杯的更多相关文章

  1. (acwing蓝桥杯c++AB组)1.1 递归

    (acwing蓝桥杯c++AB组)1.课程介绍+递归 文章目录 (acwing蓝桥杯c++AB组)1.课程介绍+递归 课程介绍 第一讲 递归与递推 递归 引入 递归的底层调用顺序 例题与练习 课程介绍 ...

  2. 第十届蓝桥杯省赛JavaB组个人题解

    前言 以下的第十届蓝桥杯Java B组省赛的题目题解只是我个人的题解,提供一些解题思路,仅作参考,如有错误,望大家指出,不甚感激,我会及时更改. 试题 A: 组队 ----- 答案:490 [问题描述 ...

  3. 第十届蓝桥杯2019年C/C++ 大学B组省赛试题

    2019年第十届蓝桥杯大赛软件类省赛C/C++大学B组 试题 A:组队 本题总分:5分 [问题描述] 作为篮球队教练,你需要从以下名单中选出 1号位至 5号位各一名球员, 组成球队的首发阵容. 每位球 ...

  4. 2019第十届蓝桥杯C++B组题解(赛后重写的,不确保答案正确性,仅供参考)

    先说一下这次的感受吧,我们考场比较乱,开始比赛了,还有的电脑有故障,(向这些人发出同情),第一次认真参加比赛,真正比赛的时候感觉没有那么正式,很乱,各种小问题,(例如博主就没找到题目在哪里,找到后又不 ...

  5. 第十届蓝桥杯JavaB组省赛真题

    试题 A: 组队 本题总分:5 分 [问题描述] 作为篮球队教练,你需要从以下名单中选出 1 号位至 5 号位各一名球员, 组成球队的首发阵容. 每位球员担任 1 号位至 5 号位时的评分如下表所示. ...

  6. 2017年蓝桥杯B组C/C++决赛题目

    2017年第八届蓝桥杯B组C/C++决赛题目 点击查看2017年蓝桥杯B组C/C++决赛题解     1.36进制 对于16进制,我们使用字母A-F来表示10及以上的数字. 如法炮制,一直用到字母Z, ...

  7. 梳理一下最近准备蓝桥杯时学习DP问题的想法

    学习时间不长,记录的只是学习过程的思路和想法,不能保证正确,代码可以在acwing上AC. 01背包问题: 1.首先是简单的01背包问题 2.先确定状态,f[i][j]表示有第i件物品,时间为j的最大 ...

  8. 2012年 蓝桥杯预赛 java 本科 题目

    2012年 蓝桥杯预赛 java 本科 考生须知: l  考试时间为4小时. l  参赛选手切勿修改机器自动生成的[考生文件夹]的名称或删除任何自动生成的文件或目录,否则会干扰考试系统正确采集您的解答 ...

  9. 蓝桥杯历届试题 地宫取宝 dp or 记忆化搜索

    问题描述 X 国王有一个地宫宝库.是 n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走 ...

随机推荐

  1. java中Error和Exception用法上有什么区别,Error是怎么回事?

    顺便提一句, 和Exception 相对应的,还有Error,Error(错误)表示系统级的错误和程序不必处理的异常,是JRE(java运行环境)的内部错误或者硬件问题,比如,另外 某一处地方的bug ...

  2. java中final变量的用法

    4.4 final变量    final变量的数值不能在初始化之后进行改变(你希望a=3,有很多用到a的场合, 你当然不能在程序中就用3来代替a). 比如: final int h = 0; 想像有一 ...

  3. 函数.python

    今日内容概要 名称空间 名字的查找顺序 作用域 global与nonlocal关键字 函数名对象 函数的嵌套 今日内容详细 1.名称空间 #名称空间其实就是存放变量名与变量名绑定关系的地方#分类1.内 ...

  4. 自己写的一个Hash文件校验软件

    原因 学校网络安全课讲到了Hash函数,老师提了一句上机操作的时候可以用自己的写的文件校验软件,所以我干脆就自己写一个. 说明 支持算法 MD5 SHA1 SHA256 SHA512 SHA384 为 ...

  5. Typora+PicGO+Gitee实现图床功能

    Typora+PicGO+Gitee实现图床功能 版本 typora(0.9.86) PicGo(2.3.0) 主要参考链接 出现问题就先看看这个 问题一 打开PicGo后安装github插件会一直安 ...

  6. Mysql、Oracle锁表处理

    MySql解锁方式 1 # 1. 查看当前数据库锁表的情况 2 SELECT * FROM information_schema.INNODB_TRX; 3 # 2. 杀掉查询结果中锁表的trx_my ...

  7. 2021.11.16 P2375 [NOI2014] 动物园(EXKMP+差分)

    2021.11.16 P2375 [NOI2014] 动物园(EXKMP+差分) https://www.luogu.com.cn/problem/P2375 题意: PS:这道神题的背景让人疑惑,重 ...

  8. C语言超全学习路线(收藏让你少走弯路)

    刚入门是否觉得C语言很难?那可能是你还没找到正确的C语言学习路线,收藏以防找不到,让你少走弯路. 基本语法 选择控制语句 if,swith 循环控制语句 while,for 控制语句相关关键字分析 变 ...

  9. 简单了解 TiDB 架构

    一.前言 大家如果看过我之前发过的文章就知道,我写过很多篇关于 MySQL 的文章,从我的 Github 汇总仓库 中可以看出来: 可能还不是很全,算是对 MySQL 有一个浅显但较为全面的理解.之前 ...

  10. stm32F103RCT6的DMA使用经历

    ​ DMA可以直接传输数据,减少了CPU的负担,是个很好的功能,但是用的时候难免会一头雾水.这次做个小小的串口收发程序就碰到了许多问题. 之前没有注意,选择了DMA的circular模式,然后奇怪的事 ...