51Nod 1593 公园晨跑(RMQ,ST表)

51Nod 1593 公园晨跑(RMQ,ST表)

http://www.51nod.com/Challenge/Problem.html#!#problemId=1593

思路

关于ST表,建议看这篇博客:https://www.cnblogs.com/YSFAC/p/7189571.html

参考胡小兔大佬的题解搞定了,写的很好,不妨看下,这里就不罗嗦了

 1 #define IO std::ios::sync_with_stdio(0);
 2 #include <bits/stdc++.h>
 3 #define iter ::iterator
 4 using namespace  std;
 5 typedef long long ll;
 6 typedef pair<ll,ll>P;
 7 #define pb push_back
 8 #define se second
 9 #define fi first
10 #define rs o*2+1
11 #define ls o*2
12 const ll inf=0x7fffffffffffffff;
13 const int N=2e5+5;
14 ll d[N],h[N],a[N],b[N];
15 ll n,q;
16 ll ma[N][20],mi[N][20],lg[N];
17 int check(int x,int y,int z){
18     if(z==1)return a[x]>a[y]?x:y;
19     return b[x]<b[y]?x:y;
20 }
21 void init(){
22     a[0]=-inf,b[0]=inf;
23     ll s=0;
24     for(ll i=1;i<=2*n;i++){
25         s+=d[i];
26         a[i]=s+h[i];
27         b[i]=s-h[i];
28         ma[i][0]=mi[i][0]=i;
29     }
30     for(ll j=1,i=0;j<=2*n;j++){
31         lg[j]=1<<(i+1)==j?++i:i;
32         //printf("j=%d: %d\n",j,lg[j]);
33     }
34     for(int j=1;(1<<j)<=2*n;j++){
35         for(int i=1;i+(1<<j)-1<=2*n;i++){
36             ma[i][j]=check(ma[i][j-1],ma[i+(1<<(j-1))][j-1],1);
37             mi[i][j]=check(mi[i][j-1],mi[i+(1<<(j-1))][j-1],0);
38         }
39     }
40 }
41 ll getma(int l,int r){
42     if(l>r)return 0;
43     int j=lg[r-l+1];
44     return check(ma[l][j],ma[r-(1<<j)+1][j],1);
45 }
46 ll getmi(int l,int r){
47     if(l>r)return 0;
48     int j=lg[r-l+1];
49     return check(mi[l][j],ma[r-(1<<j)+1][j],0);
50 }
51 ll query(int l,int r){
52     int x=getma(l,r);
53     int y=getmi(l,r);
54     if(x!=y)return a[x]-b[y];
55     int x1=check(getma(l,x-1),getma(x+1,r),1);
56     int y1=check(getmi(l,x-1),getmi(x+1,r),0);
57     return max(a[x1]-b[y],a[x]-b[y1]);
58 }
59 int main(){
60     scanf("%d%d",&n,&q);
61     for(int i=1;i<=n;i++){
62         int x=i%n+1;
63         int y=i%n+1+n;
64         scanf("%lld",&d[x]);
65         d[y]=d[x];
66     }
67     for(int i=1;i<=n;i++){
68         scanf("%lld",&h[i]);
69         h[i]*=2;
70         h[i+n]=h[i];
71     }
72     init();
73     while(q--){
74         int x,y;
75         scanf("%d%d",&x,&y);
76         if(x>y)printf("%lld\n",query(y+1,x-1));
77         else printf("%lld\n",query(y+1,n+x-1));
78     }
79     return 0;
80 }

 

转载于:https://www.cnblogs.com/ccsu-kid/p/10617555.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101017.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java的四种输入方法,你会几种?

    java的四种输入方法,你会几种?java的输入方法最常见的就是Scanner的方法,我经过查阅一些资料发现了输入方法原来还有那么多种,可以玩出不少花样,下面是我总结出的四种输入方式,有需要的可以拿去1.Scanner相关的功能Scanner的输入方法是最常见的一种,也是小编在此最推荐的一种,固定格式如下:importjava.util.Scanner;publicclassTestDemo1007_4{publicstaticvoidmain(String[]args){Scanner

    2022年7月9日
    107
  • 【C/C++面试必备】volatile 关键字

    【C/C++面试必备】volatile 关键字????作者:Linux猿????简介:CSDN博客专家????,C/C++、面试、刷题、算法尽管咨询我,关注我,有问题私聊!????关注专栏:C/C++面试通关集锦(优质好文持续更新中……)????本文来讲解一下C/C++中的关键字volatile。在日常的使用中很少使用到,但是,在面试中经常被提起,下面具体来看一下。volatile的作用是什么呢?volatile意思是易变的,是一种类型修饰符,在C/C++中用来阻止编译器因误认某段代码无法被代码本身所改变,而造成的

    2022年7月27日
    7
  • 我对嵌入式一些概念名词简单的理解「建议收藏」

    我对嵌入式一些概念名词简单的理解

    2022年3月7日
    57
  • pycharm常用快捷键详解,让你编程 事半功倍。[通俗易懂]

    pycharm常用快捷键详解,让你编程 事半功倍。[通俗易懂]pycharm常用快捷键1、编辑(Editing)Ctrl+Space:基本的代码完成(类、方法、属性)Ctrl+Alt+Space快速导入任意类Ctrl+Shift+Enter:语句完成Ctrl+P参数信息(在方法中调用参数)Ctrl+Q快速查看文档F1外部文档Shift+F1:外部文档,进…

    2022年8月25日
    15
  • 自学 6 个月 Java 找到了一份 15K 的工作,师弟的方式值得推荐给大家

    自学 6 个月 Java 找到了一份 15K 的工作,师弟的方式值得推荐给大家我有一个大学校友,他是去年8月份才开始正式学习Java的,之前在一家私企工作了5年,工资一个月只有不到6000块,日子过得很苦逼,毕竟郑州的房贷压力也不小,公司就那么大,除非领导离职,否则根本看不到晋升的希望。他刚26岁,正值青春年华,我就劝他不如改学Java,他之前学PHP的,虽然做起来项目很快,但发展前景确实不怎么乐观。我身边的很多朋友在北京做Java开发,差不多能拿到2到3万的月薪,师弟听了非常羡慕,感觉超出了他的认知范围,就下定决心开始学习Java,一共学了大

    2022年6月22日
    46
  • Latex插入图片参数设置

    Latex插入图片参数设置常用选项[htbp]是浮动格式:『h』当前位置。将图形放置在正文文本中给出该图形环境的地方。如果本页所剩的页面不够,这一参数将不起作用。『t』顶部。将图形放置在页面的顶部。『b』底部。将图形放置在页面的底部。『p』浮动页。将图形放置在一只允许有浮动对象的页面上。一般使用[htb]这样的组合,只用[h]是没有用的。这样组合的意思就是latex会尽量满足排在前面的浮动格式,就是h-t-b这个…

    2022年5月31日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号