#P5251. [LnOI2019] 第二代图灵机

    ID: 5961 远端评测题 1000ms 256MiB 尝试: 0 已通过: 0 难度: 8 上传者: 标签>线段树颜色段均摊(珂朵莉树 ODT)双指针 two-pointer

[LnOI2019] 第二代图灵机

题目背景

1989年,Abbi提出了一种抽象的计算模型 —— 第二代图灵机 (The 2nd Generation Turing Machine)。

所谓的第二代图灵机就是指一个抽象的机器,它有一条长度为nn的纸带,纸带分成了nn个小方格,每个方格有不同的颜色和不同的数字

avatar

题目描述

第二代图灵的基本思想是用机器来模拟鹿们用纸笔进行数学运算的过程,他把这样的过程看作下列两种简单的动作:

  1. 在纸带上的一格写数字。
  2. 在纸带上的一段区间着色。

为了测试第二代图灵机的性能,Abbi提出了一种用于判定机器是否具有智能的试验方法,即图灵试验。

  1. [l,r][l,r] 中包含所有(一共 cc 种)颜色,数字和最小的子区间的数字和。
  2. [l,r][l,r] 中没有重复颜色,数字和最大的子区间的数字和。

你需要为第二代图灵机编写算法,使他能通过所有的图灵试验。为保证试验的正确性,所有数据都是随机生成的。

输入格式

第一行输入两个正整数 n,m,cn,m,c,分别表示纸带长度,操作次数和颜色总数。

第二行 nn 个非负整数,表示每个格子上的初始数字 aia_i

第三行 nn 个非负整数,表示每个格子上的颜色编号 bib_i

接下来 mm 行,对应每一次操作。

操作一格式:1xy1\quad x\quad y,表示将第 xx 位的数字改为 yy,保证 1y100001≤y≤10000

操作二格式:2lry2\quad l\quad r\quad y,表示将区间 [l,r][l,r] 的颜色全部改为 yy ,保证 1yc1≤y≤c

操作三格式:3lr3\quad l\quad r,表示询问区间[l,r][l,r]中包含所有(一共cc种)颜色,数字和最小的子区间的数字和。

操作四格式:4lr4\quad l\quad r,表示询问区间[l,r][l,r]中没有重复颜色,数字和最大的子区间的数字和。

输出格式

对于操作三和操作四,输出一个整数,表示最小或最大的数字和。

对于操作三,若不存在满足条件的子区间,请输出 1-1

9 8 4
17 5 8 1 6 4 12 3 4
1 1 1 1 1 1 1 3 4
2 3 6 2
3 1 9
4 1 9
4 6 9
4 1 3
2 4 5 4
3 1 1
3 1 9
23
23
23
17
-1
23

提示

avatar

由于数据规模较大,建议用以下方法读入一个正整数。

void read(int &x){
	char ch;
	while(ch = getchar(), ch < '!'); x = ch - 48;
	while(ch = getchar(), ch > '!') x = (x << 3) + (x << 1) + ch - 48;
}