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

[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;
}