码迷,mamicode.com
首页 > 其他好文 > 详细

CF1366E Two Arrays(思维+数学)

时间:2020-07-22 02:00:03      阅读:62      评论:0      收藏:0      [点我收藏+]

标签:ons   img   技术   def   计算   clu   namespace   递增   后缀   

对于这道题,可以想想对于每个b[i],a[i]中可选的位置的区间在哪,这样只要找到区间,就能知道当前可以选那几个位置断开

b[1]的开头肯定是1号位,而我们发现如果对后缀求一下后缀的最小值,这样就天然满足题目条件,我们用一个map存一下答案,就能知道b[i]是最小值的区间是哪些

因为b是单调递增的数学因此可以从头枚举b[i]所在位置,用乘法原理进行计算。

技术图片
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=2e5+10;
const int mod=998244353;
int a[N];
int b[N];
int suffix[N];
map<int,int> cnt;
int main(){
    ios::sync_with_stdio(false);
    int n,m;
    cin>>n>>m;
    int i;
    for(i=1;i<=n;i++)
        cin>>a[i];
    for(i=1;i<=m;i++)
        cin>>b[i];
    suffix[n+1]=0x3f3f3f3f;
    for(i=n;i>=1;i--){
        suffix[i]=min(suffix[i+1],a[i]);
        cnt[suffix[i]]++;
    }
    ll ans=1;
    if(suffix[1]!=b[1]){
        cout<<0<<endl;
    }
    else{
        for(i=2;i<=m;i++){
            ans=ans*cnt[b[i]]%mod;
        }
        cout<<ans<<endl;
    }
    return 0;
}
View Code

 

CF1366E Two Arrays(思维+数学)

标签:ons   img   技术   def   计算   clu   namespace   递增   后缀   

原文地址:https://www.cnblogs.com/ctyakwf/p/13358133.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!