ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

牛客多校第一场

2019-07-22 21:08:28  阅读:227  来源: 互联网

标签:... RMQ last sta int 多校 牛客 maxn 第一场


牛客多校第一场

A. Equivalent Prefixes

题意:两个序列相等的条件是RMQ(u,l,r) = RMQ(u,l,r),(1lrm1\leq l \leq r\leq m1≤l≤r≤m) ,RMQ(u,l,r)代表序列u,的任意区间(l,r)的最小值的序号,求一个最大的P,使得{a1,a2,...ap}\lbrace a_1, a_2,...a_p \rbrace{a1​,a2​,...ap​}和{b1,b2,...bp}\lbrace b_1,b_2,...b_p \rbrace{b1​,b2​,...bp​}相等

思路:

我们假设lasta[i]=max{jj&lt;i&amp;&amp;aj&lt;ai}last_a[i]= max\lbrace j|j&lt;i \&amp;\&amp; a_j&lt;a_i\rbracelasta​[i]=max{j∣j<i&&aj​<ai​} ,也就是aia_iai​左边序号最大的小于aia_iai​的数字的位置,

我们用单调栈去求这个last,求得以后

那么我们求序列[1,r]的RMQ,就是找到last[r],last[last[r]],last[last[last[r]],的值

如果两个序列的last数组相同,那么就证明RMQ(a,l,r)=RMQ(b,l,r)RMQ(a,l,r)=RMQ(b,l,r)RMQ(a,l,r)=RMQ(b,l,r)

AC代码:

#include<bits/stdc++.h>
using namespace std;

#define ll long long
const int maxn = 1e5 + 7;
const int inf = 0x3f3f3f3f;
const int mod = 1e9 + 7;
typedef pair<int, int> pis;

int a[maxn], b[maxn];
int lasta[maxn], lastb[maxn];

stack<pis> sta;

int main() { 
    int n;
    while(~scanf("%d", &n)) {
        for (int i = 1; i <= n; i ++) scanf("%d", &a[i]);
        for (int i = 1; i <= n; i ++) scanf("%d", &b[i]);
        while(!sta.empty()) sta.pop();
        sta.push(pis{0, 0});
        for (int i = 1; i <= n; i ++) {
            while(sta.top().first > a[i]) sta.pop();
            lasta[i] = sta.top().second;
            sta.push((pis{a[i], i})); 
        }
        while(!sta.empty()) sta.pop();
        sta.push(pis{0, 0});
        for (int i = 1; i <= n; i ++) {
            while(sta.top().first > b[i]) sta.pop();
            lastb[i] = sta.top().second;
            sta.push((pis{b[i], i})); 
        }
        int cnt = 0;
        for (int i = 1; i <= n; i ++) {
            if(lasta[i] == lastb[i]) cnt ++;
            else break;
        }
        cout << cnt << endl;
    }
    return 0;
}

标签:...,RMQ,last,sta,int,多校,牛客,maxn,第一场
来源: https://blog.csdn.net/henu_jizhideqingwa/article/details/96897663

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有