QOJ.ac

QOJ

Total points: 100

# 8466. 小水题

统计

CauchySheep 出了一道小水题。

有 $n$ 个底面积相同的水槽排成一排,相邻两个水槽共用一个隔板,第 $i$ 个水槽与第 $i+1$ 个水槽之间的隔板高度为 $b_i$。最左边与最右边的隔板高度可以视为无限大。初始时所有水槽是静止的,第 $i$ 个水槽初始水位是 $a_i$。你需要维护以下两种操作:

  • 给定 $x$ 和 $h$,在第 $x$ 个水槽和第 $x+1$ 个水槽之间的隔板的高度 $h$ 处钻一个小孔。这之后一些水槽的水位会发生变化,你应该一直等到这些水槽恢复静止。
  • 给定 $x$,询问此时第 $x$ 个水槽的水位。

请你完成这道充满着水的小水题吧!

输入格式

第一行两个整数 $n, q$,分别表示水槽数和操作数。

第二行 $n$ 个由空格隔开的实数 $a_i$,表示初始水位。

第三行 $n-1$ 个由空格隔开的实数 $b_i$,表示初始隔板高度。

接下来 $q$ 行每行描述一个操作:

  • 1 x h 表示第一种操作,保证 $1 \le x \lt n$。注意 $h$ 是实数。
  • 2 x 表示第二种操作,保证 $1 \le x \le n$。

输入中出现的所有实数最多有七位小数。

输出格式

对于第二种操作,每一行输出答案。

最后一行输出 $n$ 个空格隔开的实数,表示操作结束后的每个水槽的水位。

绝对误差在 $10^{-7}$ 内即可接受。

注意你应该保证你的输出中只有实数(或整数),否则我们不能保证spj可以正常运行。

样例数据

样例输入

5 10
3 1 3 1 10
10 10 10 10
1 1 1
2 1
2 2
1 3 5
1 4 5
2 3
2 4
2 5
1 2 0
2 1

样例输出

2.00000000
2.00000000
4.00000000
5.00000000
5.00000000
2.66666667
2.66666667 2.66666667 2.66666667 5.00000000 5.00000000

样例输入

5 2
6.62 5.02 1.49 4.35 4.01
7.83 7.10 5.90 7.93
1 3 2.91
1 4 2.17

样例输出

6.62000000 5.02000000 3.28333333 3.28333333 3.28333333

子任务

在这题中,我们使用一个理想模型。即我们假设水的体积不变,并且忽视水的表面张力、摩擦力等。你可以认为钻孔之后的水位变化是符合生活常识的。你可以认为,对于两个相邻的水位 $a_i, a_{i+1}$,以及它们之间隔板存在一个高度为 $h$ 的小孔(或初始隔板高度为 $h$ ),如果有 $a_i \gt h, a_i \gt a_{i+1}$,那么将会有水从 $i$ 流向 $i+1$。对称地,如果有 $a_{i+1} \gt h, a_{i+1} \gt a_i$,那么将会有水从 $i+1$ 流向 $i$。水从 $x$ 流向 $y$ 是指 $a_x$ 不断减少,$a_y$ 不断增加,并且保持它们的和不变。

出题人友情提醒: 请妥善处理浮点数运算造成的精度误差

对于所有测试数据,$1 \le n, q \le 100000$,$0 \le a_i, h \le 100$,对于 $1 \le i \lt n$,有 $b_i \ge \max(a_i, a_{i+1})$。输入中出现的所有实数最多有七位小数。

  • 子任务 $1$($1$ 分):$1 \le n, q \le 10$;
  • 子任务 $2$($10$ 分):$1 \le n, q \le 300$;
  • 子任务 $3$($10$ 分):$1 \le n, q \le 2000$,对于 $i\gt 1$,满足 $a_i = 0$;
  • 子任务 $4$($10$ 分):$1 \le n, q \le 2000$;
  • 子任务 $5$($30$ 分):对于 $i>1$,满足 $a_i = 0$;
  • 子任务 $6$($39$ 分):无特殊限制。