首页 > 其他分享 >《双序列拓展》

《双序列拓展》

时间:2024-06-22 09:32:09浏览次数:21  
标签:测试点 int 询问 样例 拓展 序列 105

描述

称某个序列 B={b1​,b2​,⋯,bn​} 是另一个序列 A={a1​,a2​,⋯,am​} 的拓展当且仅当存在正整数序列 L={l1​,l2​,⋯,lm​},将 ai​ 替换为 li​ 个 ai​ 后得到序列 B。例如,

  • {1,3,3,3,2,2,2} 是 {1,3,3,2} 的拓展,取 L={1,1,2,3} 或 {1,2,1,3};
  • 而 {1,3,3,2} 不是 {1,3,3,3,2} 的拓展,{1,2,3} 不是 {1,3,2} 的拓展。

小 R 给了你两个序列 X 和 Y,他希望你找到 X 的一个长度为 l0​=10100 的拓展 F={fi​} 以及 Y 的一个长度为 l0​ 的拓展 G={gi​},使得任意 1≤i,j≤l0​ 都有 (fi​−gi​)(fj​−gj​)>0。由于序列太长,你只需要告诉小 R 是否存在这样的两个序列即可。

为了避免你扔硬币蒙混过关,小 R 还给了 q 次额外询问,每次额外询问中小 R 会修改 X 和 Y 中若干元素的值。你需要对每次得到的新的 X 和 Y 都进行上述的判断。

询问之间是独立的,每次询问中涉及的修改均在原始序列上完成。

输入描述

输入的第一行包含四个整数 c,n,m,q,分别表示测试点编号、序列 X 的长度、序列 Y 的长度和额外询问的个数。对于样例,c 表示该样例与测试点 c 拥有相同的限制条件。

输入的第二行包含 n 个整数 x1​,x2​,⋯,xn​,描述序列 X。

输入的第三行包含 m 个整数 y1​,y2​,⋯,ym​,描述序列 Y。

接下来依次描述 q 组额外询问。对于每组额外询问:

  • 输入的第一行包含两个整数 kx​ 和 ky​,分别表示对序列 X 和 Y 产生的修改个数。
  • 接下来 kx​ 行每行包含两个整数 px​,vx​,表示将 xpx​​ 修改为 vx​。
  • 接下来 ky​ 行每行包含两个整数 py​,vy​,表示将 ypy​​ 修改为 vy​。

输出描述

输出一行,其中包含一个长度为 (q+1) 的 01 序列,序列的第一个元素表示初始询问的答案,之后 q 个元素依次表示每组额外询问的答案。对于每个询问,如果存在满足题目条件的序列 F 和 G,输出 1,否则输出 0

样例输入 1 

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

样例输出 1 

1001

提示

【样例解释 #1】

由于 F 和 G 太长,用省略号表示重复最后一个元素直到序列长度为 l0​。如 {1,2,3,3,⋯} 表示序列从第三个元素之后都是 3。

以下依次描述四次询问,其中第一次询问为初始询问,之后的三次为额外询问:

  1. A={8,6,9},B={1,7,4},取 F={8,8,6,9,⋯},G={1,7,4,4,⋯};
  2. A={8,6,0},B={1,7,4},可以证明不存在满足要求的方案;
  3. A={8,6,9},B={8,7,5},可以证明不存在满足要求的方案;
  4. A={8,8,9},B={7,7,4},取 F={8,8,9,⋯},G={7,7,4,⋯}。

【样例解释 #2】

该组样例满足测试点 4 的条件。

【样例解释 #3】

该组样例满足测试点 7 的条件。

【样例解释 #4】

该组样例满足测试点 9 的条件。

【样例解释 #5】

该组样例满足测试点 18 的条件。

【数据范围】

对于所有测试数据,保证:

  • 1≤n,m≤5×105;
  • 0≤q≤60;
  • 0≤xi​,yi​<109;
  • 0≤kx​,ky​≤5×105,且所有额外询问的 (kx​+ky​) 的和不超过 5×105;
  • 1≤px​≤n,1≤py​≤m,0≤vx​,vy​<109;
  • 对于每组额外询问,px​ 两两不同,py​ 两两不同。
测试点编号n,m≤特殊性质
11
22
3,46
5200
6,72000
8,94×104
10,111.5×105
12∼145×105
15,164×104
17,181.5×105
19,205×105

特殊性质:对于每组询问(包括初始询问和额外询问),保证 x1​<y1​,且 xn​ 是序列 X 唯一的一个最小值,ym​ 是序列 Y 唯一的一个最大值。

	
#include <bits/stdc++.h>
 
using namespace std;
 
constexpr int N = 5e5 + 10;
 
int n, m, q, x[N], y[N], tx[N], ty[N];
bool flag;
 
struct Node {
    int pre, suf;
 
    void operator=(const int &x) {pre = suf = x;}
} X[N], Y[N];
 
bool check(const int x[], const int y[]) {
    if (x[1] == y[1]) return 0;
    else if (x[1] > y[1]) swap(x, y), swap(n, m), flag = 1;
    int mx = x[1]; X[1] = x[1], X[n] = x[n];
    for (int i = 2; i <= n; i++) mx = max(mx, x[i]), X[i].pre = min(X[i - 1].pre, x[i]);
    for (int i = n - 1; i; i--) X[i].suf = min(X[i + 1].suf, x[i]);
    int mn = y[1]; Y[1] = y[1], Y[m] = y[m];
    for (int i = 2; i <= m; i++) mn = min(mn, y[i]), Y[i].pre = max(Y[i - 1].pre, y[i]);
    for (int i = m - 1; i; i--) Y[i].suf = max(Y[i + 1].suf, y[i]);
    if (mx >= Y[1].suf || mn <= X[1].suf) return 0;
    for (int i = 1, j = 1; i <= n; i++) {
        while (j <= m && y[j] > X[i].pre) j++;
        if (j == m + 1) break;
        if (x[i] >= Y[j].pre) return 0;
    }
    for (int i = n, j = m; i; i--) {
        while (j && y[j] > X[i].suf) j--;
        if (!j) break;
        if (x[i] >= Y[j].suf) return 0;
    }
    return 1;
}
 
int main() {
    ios_base::sync_with_stdio(0); cin.tie(nullptr), cout.tie(nullptr);
    cin >> n >> n >> m >> q;
    for (int i = 1; i <= n; i++) cin >> x[i];
    for (int i = 1; i <= m; i++) cin >> y[i];
    cout << check(x, y);
    while (q--) {
        if (flag) swap(n, m), flag = 0;
        memcpy(tx, x, sizeof(tx)), memcpy(ty, y, sizeof(ty));
        int kx, ky, p, v; cin >> kx >> ky;
        while (kx--) cin >> p >> v, tx[p] = v;
        while (ky--) cin >> p >> v, ty[p] = v;
        cout << check(tx, ty);
    }
    return 0;
}

标签:测试点,int,询问,样例,拓展,序列,105
From: https://blog.csdn.net/2401_84500159/article/details/139874344

相关文章

  • 【全拓展】编译器设置
    在DEV-C++中可以进行一些编译器设置,是很必要的本篇文本是全拓展文本一、语言DEV-C++一开始是英文版的,我们要将他改为中文版,怎么办?点击按钮"Tools",打开菜单点击下面的第二个按钮选择“Language”往上看选择以下选项最后点击OK按钮(可能会弹出提示,直接选择确定)二、缺......
  • 计算机网络:408考研|重要拓展内容|冷门考点|英文缩写词(完结撒花~)
    系列目录408计算机网络总纲领更新日志6.15物理层的接口特性,修改了部分排版问题6.17数据链路层的拥塞控制,补充部分额外英文缩写词6.21考纲中明确提到的物理层的信源与信宿;数据链路层的ALOHA协议和令牌传递协议;以及运输层的UDP校验目录系列目录更新日志拓展......
  • 游戏本地化以拓展海外市场
    LogrusITKorea的总监元庆燕(KyoungYeonWon)发表了一场关于“游戏本地化”的讲座,讲述了独立游戏开发者如何在梦想拓展海外市场的过程中,正确地本地化他们的游戏以满足国际市场的期望,以及实现这一重要任务的过程。元总监首先讨论了理解本地化含义的重要性。她说,人们常常过于简......
  • 时间序列预测评价指标
    评价指标时间序列预测评价指标均方误差(MeanSquaredError,MSE)简要介绍:MSE是实际值与预测值之间差的平方的平均值。它是衡量预测精度的常用方法,适用于连续变量。优点:易于计算,对大误差有较高的敏感性。缺点:受异常值影响较大,不具有尺度无关性质。公式:......
  • 序列化和反序列化pickle和json 模块
    importpicklehello='helloworld'data=pickle.dumps(hello)#pickle.dumps把任意对象序列化成一个bytes(字节数)print(data)data1=pickle.loads(data)#pickle.loads将字节数反序列化print(data1)importjsondata={'hello':123,'nihao':'word&......
  • 数字信号处理作业 序列的卷积 实现 + MATLAB 源码
    实现有限长序列的基本运算(包括:加法、乘法、累加、移位、翻褶、抽取、插值、卷积和),并以GUI的形式将这些运算整合起来,使用者可通过向GUI输入任意有限长序列得到对应的运算结果。加法:对两个序列中对应位置的元素进行相加,得到一个新的序列,要求两个序列的长度......
  • 基于GWO-CNN-LSTM数据时间序列预测(多输入单输出)-多维时间序列模型-MATLAB实现
    基于GWO-CNN-LSTM数据时间序列预测(多输入单输出)-多维时间序列模型-MATLAB实现基于灰狼优化(GreyWolfOptimizer,GWO)、卷积神经网络(ConvolutionalNeuralNetwork,CNN)和长短期记忆网络(LongShort-TermMemory,LSTM)的多维时间序列预测模型是一种复杂且有效的深度学习方法,适......
  • ADI的CCES软件,如何申请序列号(软件注册详解)
    作者的话这些资料都在我整理的ADIDSP资料全集里,链接如下:https://item.taobao.com/item.htm?spm=a1z10.5-c.w4002-5192690539.23.76f16a87mLzgkl&id=566262352508ADI公司的DSP开发软件,CCES软件可以提供测试序列号,给大家做软件评估用,这个序列号跟正版序列号,除了一个是花巨......
  • 程序分享--常见算法/编程面试题:判断子序列
    关注我,持续分享逻辑思维&管理思维&面试题;可提供大厂面试辅导、及定制化求职/在职/管理/架构辅导;推荐专栏《10天学会使用asp.net编程AI大模型》,目前已完成所有内容。一顿烧烤不到的费用,让人能紧跟时代的浪潮。从普通网站,到公众号、小程序,再到AI大模型网站。干货满满。学成后可......
  • 港股OMD-C原始数据接口知识拓展
    OMD-C包括SS、SP、SF三个级别。简单来说,就是通过三种级别推送不同的数据,具体使用哪一档由企业自行选择。OMD-C数据服务分为实时服务、刷新服务、重传服务三部分来完成所有数据的处理。OMD-C包括约20个消息类型的数据,每天约产生3亿条数据。港交所数据持有HKEx(香港交易所)数据......