#P7881. [Ynoi2006] rmpq

    ID: 7020 远端评测题 2000ms 512MiB 尝试: 0 已通过: 0 难度: 7 上传者: 标签>2006交互题Special JudgeO2优化洛谷月赛Ynoi

[Ynoi2006] rmpq

题目描述

你需要包含头文件lib.h

在本地编译时,需要和 lib.cpp 一起编译;

交互库提供了以下数据类型和函数:

struct Data{
	unsigned short a,b,c,d;
	void operator*=(const Data &x);
	void clr();
};

Data 类型是一个含幺半群 (D,,e)(D,*,e),具体地:

DD 是类型为 Data 的元素构成的集合;

:D×DD*:D\times D\to D

eDe\in D

x,y,zD,x(yz)=(xy)z\forall x,y,z\in D, x*(y*z)=(x*y)*z

xD,xe=ex=x\forall x\in D, x*e=e*x=x

使用 x.clr() 可以将 xx 修改为 ee

使用 x=y 可以将 xx 修改为 yy

使用 x*=y 可以将 xx 修改为 xyx*y,这个操作的调用次数有常数上限 2×1072\times 10^7,不计 x=ex=ey=ey=e 的情况。

初始条件下,平面上每个点 (x,y)(x,y) 都对应一个权值 d(x,y)Dd(x,y)\in D

你需要实现以下函数:

void update(int x,int dim,Data d1,Data d2);

对每个 (x0,y0)(x_0,y_0) 执行操作:

dim=0dim=0x0<xx_0<x,则将 d(x0,y0)d(x_0,y_0) 修改为 d(x0,y0)d1d(x_0,y_0)*d1

dim=0dim=0x0xx_0\ge x,则将 d(x0,y0)d(x_0,y_0) 修改为 d(x0,y0)d2d(x_0,y_0)*d2

dim=1dim=1y0<xy_0<x,则将 d(x0,y0)d(x_0,y_0) 修改为 d(x0,y0)d1d(x_0,y_0)*d1

dim=1dim=1y0xy_0\ge x,则将 d(x0,y0)d(x_0,y_0) 修改为 d(x0,y0)d2d(x_0,y_0)*d2

Data query(int x,int y);

查询 d(x,y)d(x,y),返回值为答案。

为了您的方便,这里提供模板。请完善以下代码:

/* BEGIN HEADER: */
struct Data{
	unsigned short a,b,c,d;
	void operator*=(const Data &x);
	void clr();
};
void update(int x,int dim,Data d1,Data d2);
Data query(int x,int y);
/* END HEADER. */

#include <bits/stdc++.h>

void update(int x,int dim,Data d1,Data d2){
	// complete this
}
Data query(int x,int y){
	// complete this
}

由于洛谷的交互方法比较奇怪,所以提交的时候需要把本地的代码复制过来,放在 update, query 函数这里,和前面的 HEADER 一起提交。提交时不引用 "lib.h" 头文件。

输入格式

这是交互题,不需要这种东西。

输出格式

这是交互题,不需要这种东西。

10
2 200842854 123159544
2 192001936 902183645
2 996055655 154684468
2 957446126 232761122
1 739061119 1 4 6
1 762263616 1 5 8
1 669159682 0 10 7
2 361701640 274578757
1 392040275 0 2 8
1 800311125 1 3 2

(0,0,0,0)
(0,0,0,0)
(0,0,0,0)
(0,0,0,0)
(19,19,329,10)

提示

Idea:ccz181078,Solution:ccz181078,Code:ccz181078,Data:ccz181078

对于前 8 组数据,操作个数分别为 10,1000,10000,20000,40000,60000,80000,10510,1000,10000,20000,40000,60000,80000,10^5,且 x,y,dimx,y,dim 均匀随机选取;

对于其余数据,操作个数为 10510^5,且构成子任务。

对于所有数据: 对于 update 操作,满足 1x1091\le x\le 10^9dim{0,1}dim\in\{0,1\}; 对于 query 操作,满足 1x,y1091\le x,y\le 10^9