BZOJ 4491: 我也不知道题目名字是什么

4491: 我也不知道题目名字是什么

Time Limit: 10 Sec  Memory Limit: 512 MB
Submit: 278  Solved: 154
[Submit][Status][Discuss]

Description

给定一个序列A[i],每次询问l,r,求[l,r]内最长子串,使得该子串为不上升子串或不下降子串

Input

第一行n,表示A数组有多少元素
接下来一行为n个整数A[i]
接下来一个整数Q,表示询问数量
接下来Q行,每行2个整数l,r

Output

对于每个询问,求[l,r]内最长子串,使得该子串为不上升子串或不下降子串

Sample Input

9
1 2 3 4 5 6 5 4 3
5
1 6
1 7
2 7
1 9
5 9

Sample Output

6
6
5
6
4
//样例解释
五个询问分别对应
[1,6][1,6][2,6][1,6][6,9]

HINT

N,Q<=50000

Source

By 一个读错题的沙茶

分析:

其实就是一个很经典的思想...

既然是最长的不下降子串,也就是连续的,那么我们就差分一下,这样就转化成最长的大于等于0的连续子串...线段树维护前后缀和区间最长就好了...

其实写这道题主要目的是记录一下某只智障(我...)的事迹...

交上去怎么都TLE,然后要了数据,发现可以跑出来答案还是对的...但是跑得极其慢.....大概就是100s估计也跑不出来...

然后请来RYC小盆友来查错...我说我再怎么也不能把线段树写成$O(N^2)$的吧...刚说完一秒钟YSQ小盆友指了query的这一行...

inline M query(int l,int r,int tr){if(tree[tr].l==r&&tree[tr].r==r)return tree[tr];

  

我写成了$tree[tr].l==r$感觉自己要上天....QwQ~~~

代码:

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;const int maxn=50000+5;int n,m,a[maxn],A[maxn];struct SegmentTree{struct M{int l,r,len,lmax,rmax,mmax;}tree[maxn<<2];inline M merge(M a,M b){M res;res.l=a.l,res.r=b.r,res.len=a.len+b.len;res.lmax=a.len==a.lmax?a.len+b.lmax:a.lmax;res.rmax=b.len==b.rmax?b.len+a.rmax:b.rmax;res.mmax=max(a.rmax+b.lmax,max(a.mmax,b.mmax));return res;}inline void build(int l,int r,int tr){tree[tr].l=l;tree[tr].r=r;tree[tr].len=r-l+1;if(l==r){if(a[l]>=0)tree[tr].lmax=tree[tr].rmax=tree[tr].mmax=1;elsetree[tr].lmax=tree[tr].rmax=tree[tr].mmax=0;return;}int mid=(l+r)>>1;build(l,mid,tr<<1),build(mid+1,r,tr<<1|1);tree[tr]=merge(tree[tr<<1],tree[tr<<1|1]);}inline M query(int l,int r,int tr){if(tree[tr].l==r&&tree[tr].r==r)return tree[tr];int mid=(tree[tr].l+tree[tr].r)>>1;if(r<=mid)return query(l,r,tr<<1);else if(l>mid)return query(l,r,tr<<1|1);elsereturn merge(query(l,mid,tr<<1),query(mid+1,r,tr<<1|1));}}tr1,tr2;signed main(void){scanf("%d",&n);for(int i=1;i<=n;i++) scanf("%d",&A[i]);for(int i=1;i<n;i++) a[i]=A[i+1]-A[i];tr1.build(1,n-1,1);for(int i=1,j=n;i<j;i++,j--) swap(A[i],A[j]);for(int i=1;i<n;i++) a[i]=A[i+1]-A[i];tr2.build(1,n-1,1);scanf("%d",&m);for(int i=1,l,r;i<=m;i++){scanf("%d%d",&l,&r);if(l==r) puts("1");else printf("%d\n",max(tr1.query(l,r-1,1).mmax+1,tr2.query(n-r+1,n-l,1).mmax+1));}return 0;
}

  


By NeighThorn

转载于:https://www.cnblogs.com/neighthorn/p/6567735.html

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

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

相关文章

Spring-boot中读取config配置文件的两种方式

了解过spring-Boot这个技术的&#xff0c;应该知道Spring-Boot的核心配置文件application.properties&#xff0c;当然也可以通过注解自定义配置文件的信息。 Spring-Boot读取配置文件的方式&#xff1a; 一.读取核心配置文件信息application.properties的内容 核心配置文件是指…

JavaFX 2 GameTutorial第5部分

介绍 这是与JavaFX 2 Game Tutorial相关的六部分系列的第五部分。 我知道自从我写关于游戏的博客以来已经很长时间了&#xff0c;但希望您仍然与我在一起。 如果您想回顾一下&#xff0c;请阅读第1部分 &#xff0c; 第2 部分 &#xff0c; 第3 部分和第4 部分 &#xff0c;以了…

h5是可以一键打包小程序的_H5手机网站封装打包微信小程序并实现分享及微信支付...

手机网站打包小程序教程&#xff0c;生成小程序&#xff0c;网页版小程序 打包微信小程序&#xff0c;H5封装成微信小程序。微信小程序开发一般分为2种方式&#xff0c;一种就是原生开发小程序&#xff0c;一种是将手机网站打包成小程序。原生开发小程序成本较高&#xff0c;技…

Hive中的数据库、表、数据与HDFS的对应关系

1、hive数据库 我们在hive终端&#xff0c;查看数据库信息&#xff0c;可以看出hive有一个默认的数据库default&#xff0c;而且我们还知道hive数据库对应的是hdfs上面的一个目录&#xff0c;那么默认的数据库default到底对应哪一个目录呢&#xff1f;我们可以通过hive配置文件…

软件工程概论作业3

转载于:https://www.cnblogs.com/clueless/p/6568351.html

使用JSF的面向服务的UI

在大型软件开发项目中&#xff0c;面向服务的体系结构非常常见&#xff0c;因为它提供了可供不同团队或部门使用的功能接口。 创建用户界面时&#xff0c;应应用相同的原理。 对于具有开票部门和客户管理部门等的大型公司&#xff0c;组织结构图可能如下所示&#xff1a; 如果计…

pocib模板流程图_各单据流程POCIB

POCIB各阶段流程报关流程从广义上讲&#xff0c;报关是指进出境运输工具负责人、进出境口货物收发货人、进出境物品的所有人或者他们的代理人向海关办理运输工具、货物、物品进出境手续及相关手续的全过程。其中&#xff0c;进出境运输工具负责人、进出口货物收发货人、进出境物…

WinDbg 查看静态变量

有如下Class。若想查看静态变量内容。因为静态变量和类绑定&#xff0c;仅需要查看类即可。 namespace ConsoleApplication13 {class Program{public static string public_string "pubstr_static";public static string private_string "pristr_static"…

vue 固定div 滚动_vue.js-div滚动条隐藏但有滚动效果的实现方法

组件被包在一个高度固定的divmounted () {var boDiv document.getElementById(this.id);if(boDiv undefined){return;}var isFirefoxnavigator.userAgent.indexOf("Firefox")if(isFirefox>0){boDiv.addEventListener(DOMMouseScroll, function(event) { //火狐v…

JBoss核心Java Web服务

这篇博客文章涉及Web服务。 好吧&#xff0c;更确切地说&#xff0c;它处理JBoss上的“普通” java Web服务。 这意味着我们将创建一个没有任何其他框架&#xff08;如CXF&#xff0c;Axis等&#xff09;的Web服务。 JBoss它自己提供对Web服务的支持。 因此&#xff0c;如果您真…

JavaSE--for each

参考&#xff1a;http://blog.csdn.net/yasi_xi/article/details/25482173 学习多线程的时候实例化线程数组而挖掘出来的一直以来的理解误区 之前一直以为for each 本质上和for循环以及迭代器没什么区别 1 package foreach;2 3 public class ForeachDemo1 {4 5 public …

[BZOJ1726][Usaco2006 Nov]Roadblocks第二短路

1726: [Usaco2006 Nov]Roadblocks第二短路 Time Limit: 5 Sec Memory Limit: 64 MB Submit: 1277 Solved: 607 [Submit][Status][Discuss]Description 贝茜把家搬到了一个小农场&#xff0c;但她常常回到FJ的农场去拜访她的朋友。贝茜很喜欢路边的风景&#xff0c;不想那么快…

mysql 5.1.62_MySQL 5.5.62 安装方法(标准配置版)

1.此安装方法适用于绝大多数MySQL版本&#xff0c;首先在MySQL官网上下载好所需版本。2.(官网可能不太好找)在我的博客列表中有一篇是MySQL官网下载链接&#xff0c;直达下载界面&#xff0c;方便。3.下载。(安装版 MSI Installer)4.下载安装包然后双击开始安装选择同意协议并…

简化Java内存分析

作为一名典型的Java开发人员&#xff0c;除了遵循关闭连接&#xff0c;流等典型的最佳实践外&#xff0c;我从未监视过应用程序的内存使用情况。最近&#xff0c;我们在JBoss服务器中遇到了一些问题&#xff0c;不得不深入研究内存管理Java中最好的事情之一是&#xff0c;创建对…

nyoj 1129 Salvation 模拟

思路&#xff1a;每个坐标有四种状态&#xff0c;每个点对应的每种状态只能走一个方向&#xff0c;如果走到一个重复的状态说明根本不能走到终点&#xff0c;否则继续走即可。 坑点&#xff1a;有可能初始坐标四周都是墙壁&#xff0c;如果不判断下可能会陷入是死循环。 贴上测…

详解mysql数据库的启动与终止_详解MySQL数据库的启动与终止(一)

由于MySQL服务器具有多种安装分发&#xff0c;而且能够运行在多种操作平台之上&#xff0c;因此它的启动与停止的方法也多种多样。你可以根据实际情况使用其中的一种。在你安装、升级或者维护系统时&#xff0c;你可能需要多次启动和终止服务器&#xff0c;你需要了解启动和终止…

easyui 插入中间行

function inserrow() {var index_dx 0;var index_lt 0;var rows $(#dg).datagrid(getRows)//获取当前的数据行前期数据准备for (var i 0; i < rows.length; i) {if (rows[i][运营商] 电信) {index_dx i;dxptjss_dx parseInt(rows[i][短信平台接收数]);} else {index_…

使用JNA的透明JFrame

在“ 使JFrame透明”中&#xff0c;我展示了一种使用AWTUtilities类使框架透明的方法。 但是使用该类会导致访问限制编译时错误&#xff0c;该文章中还显示了Eclipse中的解析。 现在&#xff0c;这里是使用Java本机的版本。 我使用Java本机访问&#xff08;JNA&#xff09;库来…

Problem: Query on the tree(二分+划分树)

题目链接&#xff1a; Problem: Query on the tree Time limit: 1s Mem limit: 64 MB Problem DescriptionThere is a tree with n node, labeled from 1 to n, and the root of the tree is 1. For every node i, if its father is j, its value vivj*i%20161119, the…

day04_09 while循环03

练习题: 3.如何输入一个如下的直角三角形,用户指定输出行数:(如果上下反转,右如何实现?) ********** 以下是自己的思路,没有按照上课老师的思路,反正经过不断的测试改进得出的算法 num int(input("请输入行数")) line 1 while line < num1:lie 1 while lie &l…