灵能传输(思维 贪心)

news2024/11/20 7:24:51

题目如下:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

思路 or 题解

如果我们可以发现前缀和,对于这个题有特殊的性质,这个题就不能做出来了,不然你会想我一样卡好长时间,从不知所措。

  • a i + 1 + = a i , a i − 1 + = a i , a i − = 2 a i a_{i+1}+=a_i,a_{i−1}+=a_i,a_i−=2a_i ai+1+=ai,ai1+=ai,ai=2ai , i ≥ 2   a n d   i ≤ n − 1 i \ge 2\ and\ i \le n - 1 i2 and in1

考虑前缀和:对于每次操作,相当于交换了 s [ i − 1 ] s[i-1] s[i1] s [ i ] s[i] s[i] ,对于 s [ i + 1 ] s[i+1] s[i+1] 无影响,要求|a|最小即将前缀和数组按升序排列,找出前缀和中的最大差值即可即可(反证法可证)
s [ 0 ] = 0 s[0]=0 s[0]=0 ,由于交换对 s [ i + 1 ] s[i+1] s[i+1] 无影响,这样数据的两端就确定下来了且是无法改变的.

由于头尾两点无法改变,我们只有两条路径可以使序列的差值最小:

  • s [ 0 ] s[0] s[0] -> 最小值 -> 最大值 -> s [ n ] s[n] s[n]
  • s [ 0 ] s[0] s[0] -> 最大值 -> 最小值 -> 最大值.

以下标 i i i x x x 轴,以 s [ i ] s[i] s[i] y y y 轴,比较两条曲线可知第一种策略下最多只有两层的波折 —— 需要隔1个跳, 而在第二种策略下最多有三层的波折——需要隔两跳,隔着跳的越多,也就意味着间隔越大,所以第一种策略更优!

思考贪心的策略:假设初值较小,终值较大(因为显然我们在乎的并不是实际的序列,而仅仅是序列的最大差值 —— 而这不论是 s0<=sn,还是sn <= s0, 还是sn<=s0 情况下都是唯一的). s0 到最小值段隔着跳,最大值到 sn 段隔着跳,最小值段到最大值段直接收录剩下的元素.(注意:奇数和偶数情况略有不同)

AC 代码如下:

#define ll long long
const int N = 300009;
int n, s[N], a[N];
bool st[N];
void solve()
{
    cin >> n;
    // memset(st, 0, 1 + n);
    fill(st, st + 1 + n, 0);
    s[0] = 0;
    for (int i = 1; i <= n; i++)
    {
        cin >> a[i];
        s[i] = s[i - 1] + a[i];
    }
    int s0 = s[0], sn = s[n];
    if (s0 > sn)
        swap(s0, sn);
    sort(s, s + 1 + n);
    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;
        }
    }
    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];
    int ans = 0;
    for (int i = 1; i <= n; i++)
        ans = max(ans, abs(a[i] - a[i - 1]));
    cout << ans << '\n';
}
signed main()
{
    buff;
    int _;
    cin >> _;
    while (_--)
        solve();
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/156849.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

html 获取视频文件的宽高尺寸,怎么获取视频的宽度-解决方案

html代码 <video id"video" loop preload"auto" autoplay><source src"1.mp4" type"video/mp4">您的浏览器不支持Video标签。 </video> js代码 var videodocument.querySelector("#video");//当前视频…

Unity 之 资源加载 -- 可寻址系统使用介绍 -- 入门(三)

可寻址系统设置面板使用介绍介绍 -- 入门&#xff08;三&#xff09;一&#xff0c;可寻址系统目录介绍二&#xff0c;可寻址系统面板介绍2.1 Groups - 资源组2.2 Settings - 设置2.3 Profiles - 配置文件2.4 Event Viewer - 事件查看器2.5 Analyze - 分析工具2.6 Hosting - 托…

springAOP的注解使用

注解使用导入依赖常用注解&#xff1a;注意&#xff0c;给测试类起名字的时候千万不要定义成Test&#xff0c;测试的方法不可以有参数&#xff0c;不可以有返回值在使用注解的时候&#xff0c;还需要告诉spring应该从哪个包开始扫描,一般在定义的时候都写上相同包的路径需要导入…

GitLab安装到实战

简介 关于gitlab的入门与实战&#xff0c;这里使用的是docker安装。2核4g的话不太行。 安装 由于这里我是学习环境,所以买的是抢占式&#xff0c;配置也不是很高。 购买服务器示例 Docker安装步骤 1.安装docker yum install -y docker 2.启动docker systemctl start doc…

【JavaEE】进程和线程

目录 1. 进程 1.1 PCB 1.1.1. PID 1.1.2. 内存指针 1.1.3. 文件描述符表 1.1.4.进程调度相关的属性 1.2 进程的虚拟地址空间 1.3 进程间的通信 2. 线程 2.1 线程与进程之间的联系 2.2 多线程与多进程 1. 进程 在了解线程之前&#xff0c;我们首先要了解进程&…

RHCE学习笔记-253-3

system monitoring Introduction to system monitoring security breaches or system malfunctions can be detected with regular system monitoring system monitoring includes: file system monitoring log file analysis process monitoring file system analysis 如果定期…

谷粒商城-基础篇-Day08-调试会员等级相关接口

在P83级中&#xff0c;点击发布商品时没有出现请求 则需要解决 PubSub is not definded这个问题 PubSub是用来检测选择分类的值变动的。 选择分类值变动&#xff0c;会请求后台接口&#xff0c;动态更新选择品牌的选项。 安装依赖 npm install --save pubsub-js&#xff08…

算法队伍的搭建

&#x1f31e;欢迎来到数据结构的世界 &#x1f308;博客主页&#xff1a;卿云阁 &#x1f48c;欢迎关注&#x1f389;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f31f;本文由卿云阁原创&#xff01; &#x1f64f;作者水平很有限&#xff0c;如果发现错误&#xff…

网络安全必备1000道面试题集锦(附答案)

前言 以下为网络安全各个方向涉及的面试题&#xff0c;星数越多代表问题出现的几率越大&#xff0c;祝各位都能找到满意的工作。 注&#xff1a;本套面试题&#xff0c;已整理成pdf文档&#xff0c;但内容还在持续更新中&#xff0c;因为无论如何都不可能覆盖所有的面试问题&a…

使用ResNet18实现CIFAR10数据集的训练

如果对你有用的话&#xff0c;希望能够点赞支持一下&#xff0c;这样我就能有更多的动力更新更多的学习笔记了。&#x1f604;&#x1f604; 使用ResNet进行CIFAR-10数据集进行测试&#xff0c;这里使用的是将CIFAR-10数据集的分辨率扩大到32X32&#xff0c;因为算力相关的…

Git使用详解(图文+代码):基础内容

基础内容前言版本控制本地版本控制系统集中化版本控制系统分布式控制系统Git使用详解Git基础理解Git基础指令取得项目的Git仓库记录每次更新的仓库检查当前文件状态跟踪文件暂存已修改文件忽略某些文件查看已暂存和未暂存的更新提交更新跳过使用暂存区域移除文件远程操作的使用…

熊市里再看GameFi,为什么说链游潜力巨大?

大方向上来看&#xff0c;区块链项目本质上分为两类&#xff0c;一类是金融资产属性的项目&#xff0c;比如我们常说的DeFi、DAO、公链等&#xff0c;另一类则具有娱乐艺术属性的&#xff0c;比如NFT、GameFi、元宇宙等&#xff0c;熊市环境下如何看待这两类项目&#xff0c;以…

【iOS】—— 初识GCD

GCD&#xff08;Grand Central Dispatch&#xff09; 文章目录GCD&#xff08;Grand Central Dispatch&#xff09;什么是GCDperformSelector方法&#xff1a;GCD的优点&#xff1a;任务和队列队列的创建方式任务的创建方法六种情况的例子1.并发队列 同步执行2. 并发队列 异步…

Vector - VT System - Ethernet板卡_VT6306

前面介绍了支持CAN&CANFD&LIN板卡&#xff0c;但是对于当前日益火爆的车载以太网来说&#xff0c;Vector也是提供了类似于VN5000系列一样的板卡&#xff0c;那就是VT6306。它给提供6路的百兆或者6路千兆的车载以太网&#xff08;2022年之前选择后是固定的&#xff0c;有…

央视点赞百度智能云激活民营经济”数字“活力

2023年&#xff0c;对民营企业究竟意味着什么。 2022年12月&#xff0c;新华社发表重磅长文解读中国经济发展大势&#xff1a;“迎接更加壮阔的光明前程”。 随后央视新闻联播连续4天发声&#xff0c;关注民营经济发展。4条新闻中&#xff0c;“创新”一词共出现了29次&#…

小程序的运行机制以及安全机制

接触小程序有一段时间了&#xff0c;总得来说小程序开发门槛比较低&#xff0c;但其中基本的运行机制和原理还是要懂的. 了解小程序的由来 在小程序没有出来之前&#xff0c;最初微信WebView逐渐成为移动web重要入口&#xff0c;微信发布了一整套网页开发工具包&#xff0c;称…

199:vue+openlayers 添加删除修改feature信息,双向不同颜色指示互动

第199个 点击查看专栏目录 本示例的目的是介绍如何在vue+openlayers项目中绘制多边形,每绘制一个,左侧输出一个feature指示标志,双向颜色互动指示。 直接复制下面的 vue+openlayers源代码,操作2分钟即可运行实现效果; 注意如果OpenStreetMap无法加载,请加载其他来练习 …

前缀和讲解

目录 一、前言 二、前缀和 1、基本概念 2、前缀和与差分的关系 3、差分数组能提升修改的效率 三、例题 1、统计子矩阵&#xff08;lanqiao2109&#xff0c;2022年省赛&#xff09; &#xff08;1&#xff09;处理输入 &#xff08;2&#xff09;方法一&#xff1a;纯暴…

设计模式面试题

工厂模式是我们最常用的实例化对象模式了&#xff0c;是用工厂方法代替new操作的一种模式,工厂模式在Java程序中可以说是随处可见。本文来给大家详细介绍下工厂模式 面向对象设计的基本原则&#xff1a; OCP&#xff08;开闭原则&#xff0c;Open-Closed Principle&#xff0…

字符串函数介绍——C语言

文章目录 一、引言 二、函数的介绍与模拟实现 2、1 求字符串长度strlen&#xff08;&#xff09;函数 2、1、1 strlen&#xff08;&#xff09;函数介绍 2、1、2 strlen&#xff08;&#xff09;函数的模拟实现 2、2 字符串拷贝strcpy&#xff08;&#xff09;函数 2、2、1 s…