P16055 [CSPro 31] 坐标变换(其二)
题目背景
洛谷的测试数据仅供民间交流使用,非官方测试数据。官方评测链接:。
题目描述
对于平面直角坐标系上的坐标 $(x, y)$,小 P 定义了如下两种操作:
1. 拉伸 $k$ 倍:横坐标 $x$ 变为 $kx$,纵坐标 $y$ 变为 $ky$;
2. 旋转 $\theta$:将坐标 $(x, y)$ 绕坐标原点 $(0, 0)$ **逆时针**旋转 $\theta$ 弧度($0 \le \theta < 2\pi$)。易知旋转后的横坐标为 $x \cos \theta - y \sin \theta$,纵坐标为 $x \sin \theta + y \cos \theta$。
设定好了包含 $n$ 个操作的序列 $(t_1, t_2, \cdots, t_n)$ 后,小 P 又定义了如下查询:
- `i j x y`:坐标 $(x, y)$ 经过操作 $t_i, \cdots, t_j$($1 \le i \le j \le n$)后的新坐标。
对于给定的操作序列,试计算 $m$ 个查询的结果。
输入格式
从标准输入读入数据。
输入共 $n + m + 1$ 行。
输入的第一行包含空格分隔的两个正整数 $n$ 和 $m$,分别表示操作和查询个数。
接下来 $n$ 行依次输入 $n$ 个操作,每行包含空格分隔的一个整数(操作类型)和一个实数($k$ 或 $\theta$),形如 `1 k`(表示拉伸 $k$ 倍)或 `2 θ`(表示旋转 $\theta$)。
接下来 $m$ 行依次输入 $m$ 个查询,每行包含空格分隔的四个整数 $i、j、x$ 和 $y$,含义如前文所述。
输出格式
输出到标准输出。
输出共 $m$ 行,每行包含空格分隔的两个实数,表示对应查询的结果。
说明/提示
### 样例解释
第五个查询仅对输入坐标使用了操作八:拉伸 $0.716$ 倍。
横坐标:$159430 \times 0.716 = 114151.88$
纵坐标:$-511187 \times 0.716 = -366009.892$
由于具体计算方式不同,程序输出结果可能与真实值有微小差异,样例输出仅保留了三位小数。
### 子任务
- $80\%$ 的测试数据满足:$n, m \le 1000$;
- 全部的测试数据满足:
- $n, m \le 10^5$;
- 输入的坐标均为整数且绝对值不超过 $10^6$;
- 单个拉伸操作的系数 $k \in [0.5, 2]$;
- 任意操作区间 $t_i, \cdots, t_j$($1 \le i \le j \le n$)内拉伸系数 $k$ 的乘积在 $[0.001, 1000]$ 范围内。
### 评分方式
如果你输出的浮点数与参考结果相比,满足绝对误差不大于 $0.1$,则该测试点满分,否则不得分。
### 提示
- C/C++:建议使用 `double` 类型存储浮点数,并使用 `scanf("%lf", &x);` 进行输入,`printf("%f", x);` 输出,也可以使用 `cin` 和 `cout` 输入输出浮点数;`#include ` 后可使用三角函数 `cos()` 和 `sin()`。
- Python:直接使用 `print(x)` 即可输出浮点数 `x`;`from math import cos, sin` 后可使用相应三角函数。
- Java:建议使用 `double` 类型存储浮点数,可以使用 `System.out.print(x);` 进行输出;可使用 `Math.cos()` 和 `Math.sin()` 调用三角函数。