想查看其他题的真题及题解的同学可以前往查看:CCF-CSP真题附题解大全
试题编号: | 202309-2 |
试题名称: | 坐标变换(其二) |
时间限制: | 2.0s |
内存限制: | 512.0MB |
问题描述: | 问题描述对于平面直角坐标系上的坐标 (x,y),小 P 定义了如下两种操作:
设定好了包含 n 个操作的序列 (t1,t2,⋯,tn) 后,小 P 又定义了如下查询:
对于给定的操作序列,试计算 m 个查询的结果。 输入格式从标准输入读入数据。 输入共 n+m+1 行。 输入的第一行包含空格分隔的两个正整数 n 和 m,分别表示操作和查询个数。 接下来 n 行依次输入 n 个操作,每行包含空格分隔的一个整数(操作类型)和一个实数(k 或 θ),形如 1 k(表示拉伸 k 倍)或 2 θ(表示旋转 θ)。 接下来 m 行依次输入 m 个查询,每行包含空格分隔的四个整数 i、j、x 和 y,含义如前文所述。 输出格式输出到标准输出中。 输出共 m 行,每行包含空格分隔的两个实数,表示对应查询的结果。 样例输入
样例输出
样例说明第五个查询仅对输入坐标使用了操作八:拉伸 0.716 倍。 横坐标:159430×0.716=114151.88 纵坐标:−511187×0.716=−366009.892 由于具体计算方式不同,程序输出结果可能与真实值有微小差异,样例输出仅保留了三位小数。 评测用例规模与约定80% 的测试数据满足:n,m≤1000; 全部的测试数据满足:
评分方式如果你输出的浮点数与参考结果相比,满足绝对误差不大于 0.1,则该测试点满分,否则不得分。 提示
|
真题来源:坐标变换(其二)
感兴趣的同学可以如此编码进去进行练习提交
解题思路:
注意到一个操作是改变与原点的距离,一个操作是改变与xx轴所夹成的角度,如果考虑坐标在极坐标系下的表示形式,会发现这两种操作只是分别对其中一维进行操作,且这些操作是可逆的,且不会相互影响。
因此我们就预处理出 op[i]表示操作 1..i对距离 rr和角度 θ的影响,这是一个前缀和数组。
然后对于一个点问经过操作 l..r的结果,先对它施加1..r操作的影响,再消除 1..l−1操作的影响,即可得到 l..r操作的结果。
施加影响,就是长度 ×k,角度 +θ,消除影响,就是长度 /k,角度−θ。
最后根据r和 θ还原出x=rcosθ,y=rsinθ。
时间复杂度为 O(n+m)。
c++满分题解:
#includeusing namespace std; const double pi = acos(-1); int main(){ ios::sync_with_stdio(false); cin.tie(0); cout.tie(0); int n, m; cin >> n >> m; vector> op(n); for(auto &i : op){ int opp; double k; cin >> opp >> k; if (opp == 1) i[0] = k; else{ i[0] = 1; i[1] = k; } } for(int i = 1; i < n; ++ i){ op[i][0] *= op[i - 1][0]; op[i][1] += op[i - 1][1]; } for(int i = 0; i < m; ++ i){ int l, r, x, y; cin >> l >> r >> x >> y; -- l, -- r; double R = sqrt(1ll * x * x + 1ll * y * y), theta = 0; if (x == 0){ if (y > 0) theta = pi / 2; else theta = -pi / 2; }else{ theta = atan2(y, x); } R *= op[r][0]; theta += op[r][1]; if (l){ R /= op[l - 1][0]; theta -= op[l - 1][1]; } cout << fixed << setprecision(10) << R * cos(theta) << ' ' << R * sin(theta) << '\n'; } return 0; }
运行结果:
猜你喜欢
- 3天前(四川推进世界重要旅游目的地建设工作)四川推进世界重要旅游目的地建设
- 3天前(罗马尼亚的匈牙利族自治)江苏赴匈牙利、罗马尼亚开展文旅交流推广活动
- 3天前(天气预报 华为)2025HDC华为天气上新系统级天气智能体,引领更智能的气象服务
- 3天前(云南滇陇工程咨询有限公司)陇滇携手谋发展 文旅合作谱新篇
- 3天前(“清透会呼吸”轻松拿捏春日出游氛围感)“清透会呼吸”轻松拿捏春日出游氛围感
- 3天前(安岚度假村及酒店推出"山海之约"目的地婚礼计划)安岚度假村及酒店推出"山海之约"目的地婚礼计划
- 3天前(锦州新增两家国家aaa级旅游景区有哪些)锦州新增两家国家AAA级旅游景区
- 3天前(大连aaaaa景区)辽宁大连A级旅游景区应急救护水平整体跃升
- 3天前(“百场黄梅唱响百家景区”示范演出活动在黄山风景区举行)“百场黄梅唱响百家景区”示范演出活动在黄山风景区举行
- 3天前(海南航空现况怎样)用一场直播找到市场扩张新渠道,海南航空做对了什么?
网友评论
- 搜索
- 最新文章
- (2020广州车展哈弗)你的猛龙 独一无二 哈弗猛龙广州车展闪耀登场
- (哈弗新能源suv2019款)智能科技颠覆出行体验 哈弗重塑新能源越野SUV价值认知
- (2021款全新哈弗h5自动四驱报价)新哈弗H5再赴保障之旅,无惧冰雪护航哈弗全民电四驱挑战赛
- (海南航空现况怎样)用一场直播找到市场扩张新渠道,海南航空做对了什么?
- (visa jcb 日本)优惠面面俱到 JCB信用卡邀您畅玩日本冰雪季
- (第三届“堡里有年味·回村过大年”民俗花灯会活动)第三届“堡里有年味·回村过大年”民俗花灯会活动
- (展示非遗魅力 长安启源助力铜梁龙舞出征)展示非遗魅力 长安启源助力铜梁龙舞出征
- (阿斯塔纳航空公司)阿斯塔纳航空机队飞机数量增至50架
- (北京香港航班动态查询)香港快运航空北京大兴新航线今日首航
- (我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉)我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉
- 热门文章