U361087 [“科大国创杯”2023 年安徽省青少年信息学科普日-ACSPJ组] 行走

题目背景

“科大国创杯”2023 年安徽省青少年信息学科普日-ACSPJ组第三题

题目描述

小可可和小多来到了一个网格图上进行最短路训练。 这是一个 $n × n$ 的网格图,对于点 $(x, y)$,如果 $y < n$,则它向 $(x, y + 1)$ 有一条有向边,边权为 $ea_{x,y}$;如果 $x < n$,则它向 $(x + 1, y)$ 有一条有向边,边权为 $eb_{x,y}$。小可可需要在很短的时间内找到从 $(1, 1)$ 到 $(n, n)$ 的最短路。 然而,小多会捣乱 $q$ 次:小雪会删去图中的一条边,然后小可可就需要重新计算 $(1, 1)$ 到 $(n, n)$ 的最短路。当小可可计算完成后,小多就会恢复这条边。即:每次小多删掉的边只会影响到这一次小可可的计算。 小可可坚持尝试不借助外力,自己每次计算出答案。可惜小可可不是机器人,没过一会儿他就晕倒了。于是,计算最短路的任务就落到了你的头上。

输入格式

**为避免过大的输入量,网格图边的边权将在程序内生成。** 第一行两个正整数 $n, q$,表示网格的大小和小多捣乱的次数。 第二行两个整数 $seed$ 和 $B$,为辅助数据生成的变量。**请保证它们为全局变量且 $seed$ 是 $64$ 位无符号整形变量。** 接下来按照从第一行到第 $n$ 行,第一列到第 $n-1$ 列的顺序生成 $ea_{i,j}$ :每次生成时先调用一次 `xorshift64()`,再将 $ea_{i,j}$ 赋值为 `seed&(2B − 1)`。其中 $&$ 表示二进制按位且运算,`xorshift64()` 在题目最后给出。 再接下来按照从第一行到第 $n-1$ 行,第一列到第 $n$ 列的顺序生成 $eb_{i,j}$:每次生成时先调用一次`xorshift64()`,再将 $eb_{i,j}$ 赋值为 `seed&(2B − 1)`。 **请严格按照上述过程生成数据,中途不能自行改变 $seed$ 和 $B$ 的值,否则数据将错误生成。** 接下来 q 行,每行四个整数 $x, y, x' , y'$,表示小多捣乱删掉的一条边。保证 $x ' = x, y' = y + 1$ 或 $y' = y, x' = x + 1$。 **再次提醒,请不要自行改动 $seed,B$,`xorshift64()` 函数和程序读入/生成数据的顺序。** **此数据生成方式仅是为了减少输入量大小,标准算法不依赖于该生成方式。**

输出格式

输出 $q$ 行,每行一个整数,表示删掉给定边后 $(1, 1)$ 到 $(n, n)$ 的最短路。

说明/提示

### 数据规模与约定 对于 $20\%$ 的数据,满足 $n, q \le 5, B = 1$; 对于 $40\%$ 的数据,满足 $n, q \le 300$; 对于 $70\%$ 的数据,满足 $n \le 300$; 对于 100% 的数据,有 $2 \le n \le 5000, 1 \le q \le 10^{5}, 1 \le B \le 30, 1 \le x, y, x', y' \le n$。 ### `xorshift64()`模版 ```cpp void xorshift64() { seed ^= seed > 7; seed ^= seed