当前位置: 首页 > article >正文

P15906 [TOPC 2024] Business Magic 题解

P15906 [TOPC 2024] Business MagicLink: https://www.luogu.com.cn/problem/P15906题目描述沿街有n nn家商店按从近到远的顺序编号为1 11到n nn。上个月商店k kk的净利润为r k r_krk​。如果r k r_krk​为正表示盈利r k r_krk​美元如果r k r_krk​为负表示亏损− r k -r_k−rk​美元。作为一名商业魔法大师你拥有两种魔法可以用来改变这些商店下个月的净利润蓝魔法你可以选择一个连续的区间[ L , R ] [L, R][L,R]。该魔法的效果是将从商店L LL到商店R RR包含两端的每家商店的净利润翻倍。也就是说如果k ∈ [ L , R ] k \in [L, R]k∈[L,R]那么商店k kk下个月的净利润为2 r k 2r_k2rk​。绿魔法你可以选择任意一家商店对其施放绿魔法。绿魔法的效果是将该商店下个月的净利润变为上个月净利润的相反数。任何未受任何魔法影响的商店其下个月的净利润与上个月相同。然而施放魔法时有一些限制。你只能施放一次蓝魔法且必须在绿魔法之前施放。此外绿魔法不能施放在任何已经受到蓝魔法影响的商店上。你的任务是确定在最优施放魔法后所有商店下个月净利润总和的最大可能值。输入格式第一行包含一个整数n nn表示商店的数量。第二行包含n nn个空格分隔的整数r 1 , r 2 , … , r n r_1, r_2, \dots, r_nr1​,r2​,…,rn​其中r k r_krk​是商店k kk上个月的净利润。输出格式输出一个整数表示在最优施放魔法后所有商店下个月净利润总和的最大可能值。输入输出样例 #1输入 #15 -2 5 -3 4 -1输出 #120输入输出样例 #2输入 #27 -1 -1 -1 -1 -1 -1 -1输出 #27输入输出样例 #3输入 #34 998244353 864197532 -7 1000000000输出 #35724883756说明/提示1 ≤ n ≤ 3 × 10 5 1 \le n \le 3 \times 10^51≤n≤3×105− 10 9 ≤ r k ≤ 10 9 -10^9 \le r_k \le 10^9−109≤rk​≤109对于k ∈ { 1 , 2 , … , n } k \in \{1, 2, \dots, n\}k∈{1,2,…,n}Solution1. 题意有一个数组蓝魔法可将一段区间内的所有数字加倍绿魔法可将一段区间内所有数字变为相反数。求使用魔法后数组数字总和最大多少。2. 分析本题可算作贪心动态规划的混搭问题。为简明起见我们把初始状态叫做状态 0。贪心部分对状态 0 如果只使用绿魔法那么只要把所有亏损的店变为相反数扭亏为盈即可这种情况下的总利润就是所有数绝对值之和我们把这个已经用绿魔法全部扭亏为盈的状态叫做状态 1。动态规划部分我们考虑在状态 1 的基础上继续推演蓝魔法作用在原本就盈利r k 0 r_k0rk​0的店铺产生的额外利润是2 r k − r k r k 2r_k-r_k r_k2rk​−rk​rk​蓝魔法作用在经绿魔法扭亏为盈的店铺r k 0 r_k0rk​0由于题目限定蓝魔法不能在绿魔法已经起效的作用下继续使用因此等效结果相当于去掉已有的绿魔法换成蓝魔法产生的贡献是r k − ( − 2 r k ) 3 r k r_k-(-2r_k)3r_krk​−(−2rk​)3rk​注意3 r k 3r_k3rk​是一个负值表示的是蓝魔法相比于状态 1 产生的额外亏损。概括起来相交于状态 1蓝魔法对净利润的贡献是盈利盈一倍亏损亏三倍。建立一个在状态 1 的基础上的关于净利润的数组后这个数组显然是有正有负的所求的就是净利润数组的最大子段和。特别注意如果最大子段和为负当且仅当状态 0 下所有的数皆为负数才会出现此种情况那么最大子段和就是空串的最大子段和为零此时最优解就是不使用蓝魔法3. 代码usingSystem;classP15906{staticvoidMain(){intnConvert.ToInt32(Console.ReadLine());// 原始盈利情况long[]rawnewlong[n1];// 蓝魔法贡献通常有正有负long[]contributenewlong[n1];varinputsConsole.ReadLine().Split();for(inti1;in;i){raw[i]Convert.ToInt64(inputs[i-1]);}// 总收入longtotal0;for(inti1;in;i){totalMath.Abs(raw[i]);}// 蓝魔法效果for(inti1;in;i){// 盈利盈一倍,亏损亏三倍contribute[i]raw[i]*(raw[i]0?1:3);}// currentMax: 最大子段和extra: 全局最大子段和longcurrentMax0,extra0;for(inti1;in;i){currentMaxMath.Max(currentMaxcontribute[i],contribute[i]);extraMath.Max(extra,currentMax);}Console.WriteLine(totalextra);}}

相关文章:

P15906 [TOPC 2024] Business Magic 题解

P15906 [TOPC 2024] Business Magic Link: https://www.luogu.com.cn/problem/P15906 题目描述 沿街有 nnn 家商店,按从近到远的顺序编号为 111 到 nnn。上个月,商店 kkk 的净利润为 rkr_krk​。如果 rkr_krk​ 为正,表示盈利 rkr_krk​ 美…...

用逻辑分析仪实测STC15W408AS驱动BLDC电机:PWM波形与换相时序全解析

用逻辑分析仪实测STC15W408AS驱动BLDC电机:PWM波形与换相时序全解析 当硬件电路搭建完成,代码烧录进单片机后,真正的挑战才刚刚开始——如何验证那些看不见的电信号是否按预期工作?本文将以STC15W408AS驱动无感BLDC电机为例&#…...

模型越来越强,为什么真正拉开差距的却是向量引擎

模型越来越强,为什么真正拉开差距的却是向量引擎2026年的 AI 圈很吵。 但吵来吵去,核心其实只有一个问题。 模型更会说了。 为什么很多系统还是不好用。 答案往往不在模型参数里。 答案在入口、记忆、工具连接和上下文治理里。 你会发现一个很有意思的现…...

ARMv8-A A64内存拷贝指令优化原理与实践

1. A64内存拷贝指令概述在ARMv8-A架构的A64指令集中,内存拷贝操作被设计为一组高度优化的硬件指令,包括CPYPN、CPYMN和CPYEN三个关键指令。这些指令构成了一个完整的内存拷贝流水线,通过硬件级并行化和非临时(non-temporal)访问模式&#xff…...

从SE到Dual-Attention:手把手教你为YOLOv8或ResNet模型‘加装’注意力模块提升指标

从SE到Dual-Attention:手把手教你为YOLOv8或ResNet模型‘加装’注意力模块提升指标 在计算机视觉领域,注意力机制已成为提升模型性能的"秘密武器"。不同于完全重构网络架构,注意力模块的魅力在于其即插即用的特性——就像为汽车加装…...

ADF4350频点锁定与电源滤波实战:为什么你的VCO输出有噪声?加个钽电容试试!

ADF4350频点锁定与电源滤波实战:为什么你的VCO输出有噪声?加个钽电容试试! 在射频电路设计中,ADF4350作为一款集成VCO的宽带频率合成器,因其出色的性能和灵活性广受工程师青睐。然而,许多开发者在实际应用中…...

IT工程/项目计划概要~项目结束表(模版)

项目计划概要Ⅰ)项目启动(PROJECT INITIATION)1.EXCO(Executive Committee)审批2.已确认的意向书(Consent Letter)3.预风险评估4.合同(Contract)签署确认5.行业合规(Compliance)文档6.项目启动表7.项目章程签署确认Ⅱ)项目计划8.业…...

Swift底层多线程:POSIX线程封装与安全并发实践

1. 项目概述:当Swift遇见POSIX线程如果你在Swift里用过DispatchQueue或者Thread,有没有想过它们背后到底是怎么运作的?特别是当你的应用需要处理高并发、低延迟的任务,或者需要在Linux服务器上跑一个Swift后端服务时,仅…...

别再手动拖拽了!Unity运行时动态生成材质球,实现AR涂鸦功能的完整流程(附代码)

Unity运行时动态材质生成:打造高性能AR涂鸦系统的核心技术解析 在移动AR应用开发中,实时材质生成技术正成为提升用户体验的关键突破点。想象这样一个场景:儿童教育应用中,孩子随手绘制的涂鸦瞬间变成3D恐龙皮肤的纹理;…...

别再只会用RC了!手把手教你用运放搭建一个75Hz低通滤波器(附Multisim仿真文件)

从RC到运放:实战75Hz低通滤波器设计与Multisim验证 在电子信号处理领域,滤波器设计是每个工程师必须掌握的硬核技能。当你需要从嘈杂的传感器信号中提取有效信息,或者在音频系统中消除恼人的高频噪声时,一个性能优异的低通滤波器往…...

从“玄学”到科学:手把手教你用Python/SciPy设计有源巴特沃斯滤波器(告别手动解方程)

从“玄学”到科学:手把手教你用Python/SciPy设计有源巴特沃斯滤波器(告别手动解方程) 在电子工程领域,滤波器设计一直被视为兼具艺术与科学的复杂技艺。传统设计流程中,工程师需要反复查阅归一化表格、手动解算多项式方…...

Windows 11/10下VMware Workstation 17开机自启虚拟机完整配置流程(含权限修复与延迟启动设置)

Windows 11/10下VMware Workstation 17虚拟机开机自启全攻略 每次重启开发机都要手动启动一堆虚拟机?数据库服务、测试环境、持续集成节点需要724小时待命?VMware Workstation 17的自动启动功能能让你彻底告别重复劳动。作为在本地搭建服务环境的开发者&…...

不止于仿真:用MATLAB分析OFDM-QPSK系统抗噪声性能,这张误码率曲线图能告诉你什么?

从误码率曲线到系统优化:MATLAB深度解析OFDM-QPSK抗噪性能 在无线通信系统的设计与评估中,仿真分析是不可或缺的一环。当我们完成基础OFDM-QPSK系统的搭建后,如何从仿真结果中提取有价值的信息,进而指导系统优化?本文…...

NoFences桌面整理工具:5步打造高效整洁的Windows桌面

NoFences桌面整理工具:5步打造高效整洁的Windows桌面 【免费下载链接】NoFences 🚧 Open Source Stardock Fences alternative 项目地址: https://gitcode.com/gh_mirrors/no/NoFences 还在为Windows桌面上杂乱无章的图标而烦恼吗?NoF…...

AI插件深度对比 | Copilot、Tabnine、Codeium谁是王者

Copilot 的代码补全能力确实厉害,我试过在写 Python 函数的时候,只要输入注释,它就能自动生成函数体。比如写 “# 计算斐波那契数列”,它能直接给出递归和迭代两种实现方式。不过有时候生成的代码有点冗长,需要手动精简…...

Android BroadcastReceiver 深度解析:原理、实践与面试指南

引言 在 Android 开发中,BroadcastReceiver 是一个核心组件,用于处理系统级事件或应用内通信。它允许应用程序响应来自系统或其他应用的广播消息,如设备开机、网络状态变化或自定义事件。BroadcastReceiver 基于事件驱动的模型,帮助开发者实现松耦合的架构,提升应用的响应…...

手把手教你用STM32的编码器模式,精准读取JGB37-520电机转速(附TB6612驱动配置)

基于STM32编码器模式实现JGB37-520电机闭环控制实战指南 在智能硬件开发领域,精确控制电机转速和位置是实现高质量运动控制的基础。JGB37-520作为一款带有霍尔编码器的减速电机,配合TB6612驱动模块,可以构建完整的闭环控制系统。本文将深入解…...

XInputTest:精准测量游戏手柄轮询率与延迟的专业工具

XInputTest:精准测量游戏手柄轮询率与延迟的专业工具 【免费下载链接】XInputTest Xbox 360 Controller (XInput) Polling Rate Checker 项目地址: https://gitcode.com/gh_mirrors/xin/XInputTest 在竞技游戏和模拟飞行等高精度操作场景中,游戏手…...

深入解析Android ContentProvider:从基础到高级应用与面试准备

引言 在Android开发中,数据共享和访问控制是构建高效、安全应用的关键。ContentProvider作为Android四大组件之一,专门用于管理结构化数据的共享,提供标准化的接口供应用间安全访问数据。本文将以ContentProvider为核心领域,全面探讨其原理、实现、应用及面试常见问题。文…...

[STM32U3] 【STM32U385RG 测评】02+调试串口1输出字符串

一::STM32U385 串口知识分享 通用同步/异步收发器(USART) 这些设备有两个嵌入式通用同步接收器发送器(USART1和USART3)以及两个通用异步接收器发送器(UART4和UART5) 该USART提供了一个灵活的手段来执行全双工数据交换与外部设备需要一个行业标准的NRZ异步串行数据格…...

Cadence ADE保姆级教程:手把手教你用S参数文件提取变压器QLk指标(附完整公式)

Cadence ADE实战指南:从S参数文件到变压器QLk指标的全流程解析 在射频集成电路设计中,变压器作为关键无源器件,其性能直接影响整个系统的效率与稳定性。QLk指标(品质因数Q、电感值L和耦合系数k)的准确提取,…...

别急着加内存!PyTorch报错‘DefaultCPUAllocator: not enough memory’的另类解法(附一键修复脚本)

别急着加内存!PyTorch报错‘DefaultCPUAllocator: not enough memory’的另类解法 当你看到PyTorch抛出RuntimeError: DefaultCPUAllocator: not enough memory时,第一反应可能是检查任务管理器——然后发现物理内存明明还剩大半,这个报错就显…...

东山精密冲刺港股:第一季营收131亿 净利11亿 市值超4000亿

雷递网 雷建平 5月20日苏州东山精密制造股份有限公司(简称:“东山精密”)日前更新招股书,准备在港交所上市。截至目前,东山精密股价为219.33元,市值约4016亿元。一旦在港股上市,东山精密将形成“AH”的格局…...

保姆级教程:在RK3568开发板上搞定ES8316声卡驱动(从DTS配置到tinymix调试全流程)

RK3568开发板ES8316声卡驱动全流程实战指南 从零开始的声音之旅 当你第一次拿到RK3568开发板,想要实现音频功能时,ES8316这颗高性能低功耗的音频编解码芯片可能会成为你的首选。但在嵌入式Linux环境下,从硬件连接到软件驱动,再到最…...

Redis对象类型与底层数据结构

一、Redis对象类型概述 1.1 Redis数据类型总览 Redis提供了丰富的数据类型,用于不同的业务场景:对象类型说明典型场景String字符串缓存、计数器、分布式锁List双向链表队列、消息队列、最新列表Hash哈希表存储对象、购物车Set无序集合好友关系、抽奖Zset…...

5个关键挑战:BiliTools跨平台架构如何应对大规模视频下载的性能瓶颈

5个关键挑战:BiliTools跨平台架构如何应对大规模视频下载的性能瓶颈 【免费下载链接】BiliTools A cross-platform bilibili toolbox. 跨平台哔哩哔哩工具箱,支持下载视频、番剧等等各类资源 项目地址: https://gitcode.com/GitHub_Trending/bilit/Bil…...

nuScenes数据集“平替”指南:Mini版够用吗?完整版、Test版到底怎么选?

nuScenes数据集选型实战指南:从Mini版到完整版的决策逻辑 第一次接触nuScenes数据集时,面对动辄几百GB的庞然大物和仅有3.9GB的mini版本,相信不少研究者都会陷入选择困难。这就像站在自助餐厅里,既想品尝所有美味,又担…...

Sora 2生成帧精度达99.7%的LUT匹配方案,DaVinci色彩科学全链路对齐指南

更多请点击: https://kaifayun.com 第一章:Sora 2与DaVinci整合的底层逻辑与技术共识 Sora 2 作为新一代视频生成基础模型,其核心能力建立在时空联合建模与长程依赖捕获之上;DaVinci 则是面向专业影视工作流的高性能非线性编辑与…...

蓝桥杯嵌入式LCD显示避坑指南:sprintf函数格式化变量显示的正确姿势

蓝桥杯嵌入式LCD显示避坑指南:sprintf函数格式化变量显示的正确姿势 在蓝桥杯嵌入式竞赛中,LCD显示是基础但至关重要的环节。许多参赛选手在实现变量动态显示时,常常因为对sprintf函数的使用不当而陷入各种"坑"中——数据显示不全、…...

2026年多Agent协作实战:用CrewAI搭建5角色AI开发团队

前言上一篇我们学习了MCP协议,掌握了AI与工具交互的标准化方法。本文将更进一步,探讨如何让多个AI Agent协同工作——就像组建一个AI开发团队,每个Agent负责不同的角色,通过协作完成复杂任务。—## 一、为什么需要多Agent协作&…...