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

最大子序和+旅行问题——单调队列

一、最大子序和

输入一个长度为 n 的整数序列,从中找出一段长度不超过 m 的连续子序列,使得子序列中所有数的和最大。
注意: 子序列的长度至少是 1。

输入
第一行输入两个整数 n,m (1 ≤ n,m ≤ 300000)。
第二行输入 n 个数,代表长度为 n 的整数序列。
同一行数之间用空格隔开。

输出
输出一个整数,代表该序列的最大子序和。

Input
6 4
1 -3 5 1 -2 3

Output
7

解析:
在长度不超过m的连续子序列,找到和最大的连续子序列。
集合按照终点的不同划分,划分成 n 个子集,答案就是不同子集的最大值。
假如,终点是 k 的连续子序列,它的最大和就是 max({a[k],a[k]+a[k-1],a[k]+a[k-1]+a[k-2],……,a[k]+…a[k-m+1]});
可以发现就是 s[k]-s[k-j] 的最大值,(其中1≤j≤m,s[N]是前缀和);
又因为终点 k 是确定不动的,这道题就转化成求在区间长度不超过 m 的 s[k-j]的最小值,典型的滑动窗口问题。 

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
#define ios ios::sync_with_stdio(false),cin.tie(nullptr),cout.tie(nullptr);
int gcd(int a,int b) { return b? gcd(b,a%b) : a; }
typedef pair<int,int> PII;
const double PI=acos(-1.0);
const int N=2e6+10;
int n,m;
int s[N];
int q[N];
void solve()
{cin>>n>>m;for (int i=1;i<=n;i++) cin>>s[i],s[i] +=s[i-1];int hh=0,tt=1;                                  //最开始队列不空,有s[0]int ans=s[1];for (int i=1;i<=n;i++){if (hh<=tt&&i-q[hh]>m) hh++;ans=max(ans,s[i]-s[q[hh]]);                 //比较每个子集,更新答案while (hh<=tt&&s[q[tt]]>=s[i]) tt--;q[++tt]=i;}cout<<ans;
}
signed main()
{ios;int T=1;//cin>>T;while (T--) solve();return 0;
}

二、 旅行问题

John 打算驾驶一辆汽车周游一个环形公路。
公路上总共有 n 个车站,每站都有若干升汽油(有的站可能油量为零),每升油可以让汽车行驶一千米。
John 必须从某个车站出发,一直按顺时针(或逆时针)方向走遍所有的车站,并回到起点。
在一开始的时候,汽车内油量为零,John 每到一个车站就把该站所有的油都带上(起点站亦是如此),行驶过程中不能出现没有油的情况。
任务:判断以每个车站为起点能否按条件成功周游一周。

输入
第一行是一个整数 n (3 ≤ n ≤ 1e6),表示环形公路上的车站数;
接下来 n 行,每行两个整数 pi,di (0 ≤ pi ≤ 2e9,0 ≤ di ≤ 2e9),分别表示表示第 i 号车站的存油量和第 i 号车站到 顺时针方向 下一站的距离。

输出
输出共 n 行,如果从第 i 号车站出发,一直按顺时针(或逆时针)方向行驶,能够成功周游一圈,则在第 i 行输出 TAK,否则输出 NIE。

Input
5
3 1
1 2
5 2
0 1
5 4

Output
TAK
NIE
TAK
NIE
TAK

 

解析:
破链成环,可以根据顺时针和逆时针分开求;
下面先考虑顺时针的情况:
开一个数组存储的是 当前点的油量*100-到下一点的距离的前缀和 ;
而我们判断的是 当前点绕一圈,能否到达每一个点,就等价于 从当前点开始,到最后,每一个点的前缀和是否都大于 0 ;
而判断每个点的前缀和是否都大于0,就等价于判断最小值是否大于 0 ;
综上所述,就转化为求以每个点为起点,求在长度不超过 n 的数组的最小值是否大于0,即 区间[i,i+n-1]的最小值是否大于0,又转化成经典的滑动窗口问题!!!
(为什么要判断每个点的前缀和大于0?  如果能从起点到达当前点,那一定是之前每个站点的油量*1000之和-到达之前点的每段距离大于0,恰好就是这个新开数组能表达这种关系)

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
#define ios ios::sync_with_stdio(false),cin.tie(nullptr),cout.tie(nullptr);
int gcd(int a,int b) { return b? gcd(b,a%b) : a; }
typedef pair<int,int> PII;
const double PI=acos(-1.0);
const int N=2e6+10;
int n;
int o[N],d[N];
int s[N];
int q[N];
bool vis[N];
void solve()
{cin>>n;for (int i=1;i<=n;i++) cin>>o[i]>>d[i];for (int i=1;i<=n;i++) s[i+n]=s[i]=o[i]-d[i];for (int i=1;i<=2*n;i++) s[i] +=s[i-1];int hh=0,tt=0;q[0]=2*n+1;for (int i=2*n;i>=0;i--){if (hh<=tt&&q[hh]>i+n) hh++;if (i<n){if(s[q[hh]]-s[i]>=0) vis[i+1]=1;}while (hh<=tt&&s[q[tt]]>=s[i]) tt--;q[++tt]=i;}d[0]=d[n];for (int i=1;i<=n;i++) s[i+n]=s[i]=o[i]-d[i-1];for (int i=1;i<=2*n;i++) s[i] +=s[i-1];hh=0,tt=0;q[0]=0;for (int i=1;i<=2*n;i++){if (hh<=tt&&q[hh]<i-n) hh++;if (i>n){if (s[i]-s[q[hh]]>=0) vis[i-n]=1;}while (hh<=tt&&s[q[tt]]<=s[i]) tt--;q[++tt]=i;}for (int i=1;i<=n;i++){if (vis[i]) cout<<"TAK\n";else cout<<"NIE\n";}
}
signed main()
{ios;int T=1;//cin>>T;while (T--) solve();return 0;
}

相关文章:

最大子序和+旅行问题——单调队列

一、最大子序和 输入一个长度为 n 的整数序列&#xff0c;从中找出一段长度不超过 m 的连续子序列&#xff0c;使得子序列中所有数的和最大。 注意&#xff1a; 子序列的长度至少是 1。 输入 第一行输入两个整数 n,m (1 ≤ n,m ≤ 300000)。 第二行输入 n 个数&#xff0c;代…...

Unity设备分级策略

Unity设备分级策略 前言 之前自己做的设备分级策略&#xff0c;在此做一个简单的记录和思路分享。希望能给大家带来帮助。 分级策略 根据拟定的评分标准&#xff0c;预生成部分已知机型的分级信息&#xff0c;且保存在包内&#xff1b;如果设备没有被评级过&#xff0c;则优…...

自己在开发AI应用的过程总结的 Prompt - 持续更新

自己在开发AI应用的过程总结的 Prompt - 持续更新 0. 引言1. 让模型以"中文"进行回复2. 控制模型仅输出"hi"3. 让模型"提供简单、清晰而具体的回答"4. 让模型"在最后说谢谢" 0. 引言 我想&#xff0c;我们多半有着相似的经历&#xf…...

STM32——OLED菜单

文章目录 一.补充二. 二级菜单代码 简介&#xff1a;首先在我的51 I2C里面有OLED详细讲解&#xff0c;本期代码从51OLED基础上移植过来的&#xff0c;可以先看完那篇文章&#xff0c;在看这个&#xff0c;然后按键我是用的定时器扫描不会堵塞程序,可以翻开我的文章有单独的定时…...

Open CASCADE学习|布尔运算后消除内部拓扑

在CAD建模中&#xff0c;布尔运算是一种逻辑运算方法&#xff0c;通过这种方法&#xff0c;可以创建、修改或组合几何对象。布尔运算主要包括并集&#xff08;UNION&#xff09;、交集&#xff08;INTERSECT&#xff09;和差集&#xff08;SUBTRACT&#xff09;三种运算。 并集…...

【数据仓库】主题域和数据域

数据域与主题域区别 https://www.cnblogs.com/datadance/p/16898254.html 数据域是自下而上&#xff0c;以业务数据视角来划分数据&#xff0c;一般进行完业务系统数据调研之后就可以进行数据域的划分。针对公共明细层&#xff08;DWD&#xff09;进行主题划分。主题域则自上而…...

C#,二分法(Bisection Method)求解方程的算法与源代码

1 二分法 二分法是一种分治算法&#xff0c;是一种数学思维。 对于区间[a&#xff0c;b]上连续不断且f&#xff08;a&#xff09;f&#xff08;b&#xff09;<0的函数yf&#xff08;x&#xff09;&#xff0c;通过不断地把函数f&#xff08;x&#xff09;的零点所在的区间…...

Portainer安装/快速上手

前置&#xff1a; 管理docker容器的工具 Portainer: Container Management Software for Kubernetes and Docker https://docs.portainer.io/v/ce-2.9/start/install/server/docker/linux 官网安装教程 Install Portainer CE with Docker on Linux - Portainer Documentat…...

恢复被.target勒索病毒加密的数据文件:拒绝向.target勒索病毒支付赎金

引言&#xff1a; 在当今数字时代&#xff0c;勒索病毒已成为网络安全领域的一大威胁&#xff0c;而.target勒索病毒是其中引起广泛关注的一种变种。本文将深入探讨.target勒索病毒的特点以及被其加密的数据文件恢复方法。数据的重要性不容小觑&#xff0c;您可添加我们的技术…...

【Linux网络编程六】服务器守护进程化Daemon

【Linux网络编程六】服务器守护进程化Daemon 一.背景知识&#xff1a;前台与后台二.相关操作三.Linux的进程间关系四.自成会话五.守护进程四步骤六.服务器守护进程化 一.背景知识&#xff1a;前台与后台 核心知识就是一个用户在启动Linux时&#xff0c;都会给一个session会话&a…...

MySQL之json数据操作

1 MySQL之JSON数据 总所周知&#xff0c;mysql5.7以上提供了一种新的字段格式json&#xff0c;大概是mysql想把非关系型和关系型数据库一口通吃&#xff0c;所以推出了这种非常好用的格式&#xff0c;这样&#xff0c;我们的很多基于mongoDB的业务都可以用mysql去实现了。当然…...

【大厂AI课学习笔记】【2.1 人工智能项目开发规划与目标】(5)数据管理

今天学习了数据管理&#xff0c;以及数据管理和数据治理的区别和联系。 数据管理&#xff1a;利用计算机硬件和软件技术对数据进行有效的收集、存储、处理和应用的过程其目的在于充分有效地发挥数据的作用。 实现数据有效管理的关键是数据组织。 数据管理和数据治理的区别&am…...

Linux满载CPU和运行内存的方法

查询CPU详细信息命令如下&#xff1a; 查看物理CPU型号&#xff1a; cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c查看物理CPU个数 cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l查看每个物理CPU中core的个数(即核数) cat /proc/cpuinfo…...

每日五道java面试题之java基础篇(九)

目录&#xff1a; 第一题 你们项⽬如何排查JVM问题第二题 ⼀个对象从加载到JVM&#xff0c;再到被GC清除&#xff0c;都经历了什么过程&#xff1f;第三题 怎么确定⼀个对象到底是不是垃圾&#xff1f;第四题 JVM有哪些垃圾回收算法&#xff1f;第五题 什么是STW&#xff1f; 第…...

spring @Transactional注解参数详解

事物注解方式: Transactional 当标于类前时, 标示类中所有方法都进行事物处理 , 例子: 1 Transactional public class TestServiceBean implements TestService {}当类中某些方法不需要事物时: Transactional public class TestServiceBean implements TestService {private…...

D - 串结构练习——字符串连接

串结构练习——字符串连接 Description 给定两个字符串string1和string2&#xff0c;将字符串string2连接在string1的后面&#xff0c;并将连接后的字符串输出。 连接后字符串长度不超过110。 Input 输入包含多组数据&#xff0c;每组测试数据包含两行&#xff0c;第一行代表s…...

什么样的服务器是高性能服务器?

首先&#xff0c;高性能服务器应具备高处理能力。随着业务的不断扩展和数据量的爆炸性增长&#xff0c;高性能服务器需要具备强大的计算能力&#xff0c;能够快速处理各种复杂的业务和数据。这要求高性能服务器采用先进的处理器技术&#xff0c;如多核处理器、GPU加速等&#x…...

数学建模【线性规划】

一、线性规划简介 线性规划通俗讲就是“有限的资源中获取最大的收益”&#xff08;优化类问题&#xff09;。而且所有的变量关系式都是线性的&#xff0c;不存在x、指数函数、对数函数、反比例函数、三角函数等。此模型要优化的就是在一组线性约束条件下&#xff0c;求线性目标…...

ChatGPT的大致原理

国外有个博主写了一篇博文&#xff0c;名字叫TChatGPT: Explained to KidsQ」&#xff0c; 直译过来就是&#xff0c;给小孩子解释什么是ChatGPT。 因为现实是很多的小孩子已经可以用父母的手机版ChatGPT玩了 &#xff0c;ChatGPT几乎可以算得上无所不知&#xff0c;起码给小孩…...

蓝桥杯备赛_python_BFS搜索算法_刷题学习笔记

1 bfs广度优先搜索 1.1 是什么 1.2怎么实现 2案例学习 2.1.走迷宫 2.2.P1443 马的遍历 2.3. 九宫重排&#xff08;看答案学的&#xff0c;实在写不来&#xff09; 2.4.青蛙跳杯子&#xff08;学完九宫重排再做bingo&#xff09; 2.5. 长草 3.总结 1 bfs广度优先搜索 【P…...

别再手动改文献了!手把手教你定制Mendeley的GB/T 7714-2005引用格式(附常见问题修复)

深度定制Mendeley文献引用格式&#xff1a;GB/T 7714-2005实战指南 科研写作中&#xff0c;文献引用格式的规范性直接影响论文的专业程度。许多研究者在使用Mendeley内置的GB/T 7714-2005格式时&#xff0c;常遇到作者名全大写、et al.显示异常等问题。本文将提供一套完整的解…...

B站视频转文字终极指南:3步快速提取视频字幕和文案

B站视频转文字终极指南&#xff1a;3步快速提取视频字幕和文案 【免费下载链接】bili2text Bilibili视频转文字&#xff0c;一步到位&#xff0c;输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 还在为B站视频内容无法搜索而烦恼吗&#xff1…...

御坂翻译器:终极Galgame实时翻译解决方案,5分钟开启无障碍游戏体验

御坂翻译器&#xff1a;终极Galgame实时翻译解决方案&#xff0c;5分钟开启无障碍游戏体验 【免费下载链接】MisakaTranslator 御坂翻译器—Galgame/文字游戏/漫画多语种实时机翻工具 项目地址: https://gitcode.com/gh_mirrors/mi/MisakaTranslator 你是否曾因语言障碍…...

从订阅到命令面板:全面理解 SAP Business Application Studio 中的 SAP Fiori 开发入口

在很多 SAP Fiori 项目里,团队把精力都放在 SAPUI5、OData、Fiori elements、注解模型和部署流程上,却常常低估了开发环境本身对效率的影响。等到项目进入多人协作、跨系统联调、权限分配和模板生成阶段,大家才会发现,开发工具并不只是一个写代码的地方,它实际上决定了团队…...

深入解析PCI中断路由:从硬件引脚到操作系统中断处理的完整链路

1. 项目概述与核心问题在计算机硬件系统里&#xff0c;中断机制是设备与处理器高效通信的生命线。它允许设备在需要处理器服务时&#xff0c;主动“打断”处理器当前的工作流&#xff0c;而不是让处理器不断地去“询问”设备的状态。对于PCI&#xff08;Peripheral Component I…...

AI Coding 言出法随,未来什么还会值钱?

本文整理自播客《AI炼金术》任鑫&#xff08;云九资本&#xff09;与徐文浩的深度对话&#xff0c;探讨 AI Coding 如何重塑个人开发方式、组织形态&#xff0c;以及在生产力极大释放的时代&#xff0c;究竟什么能力还会持续增值。—本文资料通过Ai好记智能解析获取。一、AI Co…...

从源头到治理:光伏并网逆变器直流分量抑制技术全解析

1. 光伏并网逆变器直流分量问题概述 第一次在光伏电站现场看到直流分量超标告警时&#xff0c;我盯着监控屏幕愣了半天。作为从业多年的光伏系统工程师&#xff0c;我深知这个看似微小的技术指标背后隐藏着多大的隐患。直流分量就像电网中的"隐形杀手"&#xff0c;它…...

Arm SMIN指令解析:多向量最小值计算与优化实践

1. Arm SMIN指令深度解析&#xff1a;多向量最小值计算实战指南在Armv9架构的SVE2指令集中&#xff0c;SMIN&#xff08;Signed Minimum&#xff09;指令作为向量处理的重要成员&#xff0c;专门用于计算多组向量元素间的有符号最小值。我第一次在嵌入式AI项目中用到这个指令时…...

Graph-CoT:图神经网络结合思维链,实现复杂图结构推理

1. 项目概述&#xff1a;当图神经网络遇上思维链推理最近在复现和优化一些图相关的推理任务时&#xff0c;我反复遇到了一个瓶颈&#xff1a;传统的图神经网络模型在处理需要多步逻辑推理的问题时&#xff0c;比如社交网络中的影响力传播预测、知识图谱上的复杂问答&#xff0c…...

更换背景图用什么工具?8个月来我测试过50+款产品,这是真实体验分享

买了新手机&#xff0c;想给证件照换个背景&#xff1b;电商运营需要批量处理商品图&#xff1b;自媒体博主要给头像去个背景……这些场景下&#xff0c;"更换背景图用什么工具"可能是你Google搜索框里最常打的一句话。说实话&#xff0c;这个问题看似简单&#xff0…...