首页 > 其他分享 >CCF认证-202309-02 | 坐标变换(其二)

CCF认证-202309-02 | 坐标变换(其二)

时间:2024-12-01 14:59:56浏览次数:12  
标签:02 CCF 202309 t2 t1 num include pre1 pre2

对于平面直角坐标系上的坐标 (x,y),小 P 定义了如下两种操作:

  1. 拉伸 k 倍:横坐标 x 变为 kx,纵坐标 y 变为 ky;
  2. 旋转 θ:将坐标 (x,y) 绕坐标原点 (0,0) 逆时针旋转 θ 弧度(0≤θ<2π)。易知旋转后的横坐标为 xcosθ−ysinθ,纵坐标为 xsinθ+ycosθ。

设定好了包含 n 个操作的序列 (t1,t2,…,tn) 后,小 P 又定义了如下查询:

  • i j x y:坐标 (x,y) 经过操作 ti,…,tj(1≤i≤j≤n)后的新坐标。

对于给定的操作序列,试计算 m 个查询的结果。

输入格式

输入共 n+m+1 行。

输入的第一行包含空格分隔的两个正整数 n 和 m,分别表示操作和查询个数。

接下来 n 行依次输入 n 个操作,每行包含空格分隔的一个整数(操作类型)和一个实数(k 或 θ),形如 1 k(表示拉伸 k 倍)或 2 θ(表示旋转 θ)。

接下来 m 行依次输入 m 个查询,每行包含空格分隔的四个整数 i、j、x 和 y,含义如前文所述。

输出格式

输出共 m 行,每行包含空格分隔的两个实数,表示对应查询的结果。

如果你输出的浮点数与参考结果相比,满足绝对误差不大于 0.1,则该测试点满分,否则不得分。

数据范围

1≤n,m≤105,
输入的坐标均为整数且绝对值不超过 106,
单个拉伸操作的系数 k∈[0.5,2],
任意操作区间 ti,…,tj(1≤i≤j≤n)内拉伸系数 k 的乘积在 [0.001,1000] 范围内。

输入样例:
10 5
2 0.59
2 4.956
1 0.997
1 1.364
1 1.242
1 0.82
2 2.824
1 0.716
2 0.178
2 4.094
1 6 -953188 -946637
1 9 969538 848081
4 7 -114758 522223
1 9 -535079 601597
8 8 159430 -511187
输出样例:
-1858706.758 -83259.993
-1261428.46 201113.678
-75099.123 -738950.159
-119179.897 -789457.532
114151.88 -366009.892
样例解释

第五个查询仅对输入坐标使用了操作八:拉伸 0.716 倍。

横坐标:159430×0.716=114151.88159430×0.716=114151.88

纵坐标:−511187×0.716=−366009.892−511187×0.716=−366009.892

由于具体计算方式不同,程序输出结果可能与真实值有微小差异,样例输出仅保留了三位小数。

题解:

        看完题目,第一步想到的应该是直接采用模拟的方法,但是这是第二题,所以应该会超时,于是再观察题目,发现操作1和操作2是互不相关的,所以可以将两种操作分开分别采用前缀和和前缀积来记录来降低时间复杂度。

        再来看题目的输入,采用double的数据类型即可,建立pre1来记录前缀积,即扩展长度,建立pre2来记录前缀和,即旋转角度。

        但是关注到只给了操作序号,不知道这其中有几个操作1和2。所以建立一个数组num,分别记录从序号n1到n2中,分别有几个操作1和操作2。

        现在就很简单了,按照步骤一个一个打下来就好,但是要注意,在循环m个操作的时候,旋转中先记录你的x和y,否则在计算y时会使用计算后的x。

代码: 
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<iomanip>
#include<queue>
#include<stack>
#include<vector>
#include<unordered_set>
#include<unordered_map>
#include<map>
#include<set>
using namespace std;
typedef long long int ll;

int m=0,n=0,i,j;
double op1=0,op2=0;
double pre1[500001];
int p1=1;
double pre2[500001];
int p2=1;
int num[500001][2]={{0}};
int t1=0,t2=0;
double t3=0,t4=0;

main(){
    cin >> n >> m;
    pre1[0]=1;
    pre2[0]=0;
    for(i=1;i<=n;i++){
        cin >> op1 >> op2;
        if(op1==1){
            num[i][0]=num[i-1][0]+1;
            num[i][1]=num[i-1][1];
            pre1[p1]=op2*pre1[p1-1];
            p1++;
        }
        else if(op1==2){
            num[i][0]=num[i-1][0];
            num[i][1]=num[i-1][1]+1;
            pre2[p2]=op2+pre2[p2-1];
            p2++;
        }
    }
    while(m>0){
        cin >> t1 >> t2 >> t3 >> t4;
        double t;
        t3*=pre1[num[t2][0]]/pre1[num[t1-1][0]];
        t4*=pre1[num[t2][0]]/pre1[num[t1-1][0]];
        t=t3;
        t3=t3*cos(pre2[num[t2][1]]-pre2[num[t1-1][1]])-t4*sin(pre2[num[t2][1]]-pre2[num[t1-1][1]]);
        t4=t*sin(pre2[num[t2][1]]-pre2[num[t1-1][1]])+t4*cos(pre2[num[t2][1]]-pre2[num[t1-1][1]]);
        printf("%.3lf %.3lf\n",t3,t4);
        m--;
    }
}

标签:02,CCF,202309,t2,t1,num,include,pre1,pre2
From: https://blog.csdn.net/2301_78848414/article/details/144131549

相关文章

  • [2024NOIP 躺平记] 彻底反思 CSP2024
    在此向退役的WEAK101高二学长致敬。CSP2024游记昨天考完了NOIP(虽然我没考),今天来机房再次沉浸在CSPT2简单小贪心没做出来的悲痛中。那么我们需要思考几个问题:为什么T2的贪心没有想出来为什么T2没想出来会导致总分只有160pts为什么这么久了仍旧沉浸在过去而不......
  • 洛谷P11361 [NOIP2024] 编辑字符串
    ProblemSolve首先任意更换相邻元素任意次等同于在可交换范围内随便移动这题是求最优解,直观想到DP和贪心,但是容易反应过来本题DP的话很难做到无后效性,且状态较多,故尝试贪心不难发现,我们从左往右遍历的某个时刻进行交换后所得到的局部最优解总是答案的一种方案的一部分原因......
  • JVM学习-02-Java内存区域与内存溢出异常
    第二章、Java内存区域与内存溢出异常2.1概述介绍Java虚拟机内存的各个区域讲解这些区域的作用、服务对象以及其中可能产生的问题2.2运行时数据区域2.2.1运行时数据区域程序计数器:当前线程所执行的字节码的行号指示器,每条线程都需要有一个独立的程序计数器(线程私有),......
  • 2024-2025-1 学号20241315《计算机基础与程序设计》第十周学习总结
    作业信息这个作业属于哪个课程2024-2025-1-计算机基础与程序设计这个作业要求在哪里<作业要求的链接>(https://www.cnblogs.com/rocedu/p/9577842.html#WEEK10)这个作业的目标信息系统数据库与SQL人工智能与专家系统人工神经网络模拟与离散事件排队系统天气......
  • 20241201每日一题洛谷P1683
    普及-每日一题洛谷P1683题目描述不是任何人都可以进入桃花岛的,黄药师最讨厌像郭靖一样呆头呆脑的人。所以,他在桃花岛的唯一入口处修了一条小路,这条小路全部用正方形瓷砖铺设而成。有的瓷砖可以踩,我们认为是安全的,而有的瓷砖一踩上去就会有喷出要命的毒气,那你就死翘翘了,我们认为......
  • 2024-2025-1 20241421 刘庆安《计算机基础与程序设计》第十周学习总结
    这个作业属于哪个课程2024-2025-1-计算机基础与程序设计)这个作业要求在哪里https://www.cnblogs.com/rocedu/p/9577842.html#WEEK10这个作业的目标信息系统、数据库与SQL、人工智能与专家系统、人工神经网络、模拟与离散事件、排队系统、天气与地震模型、图形图像......
  • 20222412 2021-2022-2 《网络与系统攻防技术》实验七实验报告
    202224122021-2022-2《网络与系统攻防技术》实验七实验报告1.实验内容本实践的目标理解常用网络欺诈背后的原理,以提高防范意识,并提出具体防范方法。具体实践有(1)简单应用SET工具建立冒名网站SET工具是一款开源的社会工程学渗透测试工具,专门用于模拟各种社会工程学攻击场景。......
  • 20222310 2024-2025-1 《网络与系统攻防技术》实验七实验报告
    一、实验内容1.本周学习内容(1)一些web安全的知识,复习了相关web的基础知识,比如:前、后端的区别,前后端的语言如HTML,CSS,JS,GO等(2)一些数据库攻击的知识,如SQL注入2.实验内容本实践的目标理解常用网络欺诈背后的原理,以提高防范意识,并提出具体防范方法。具体实践有(1)简单应用SET工具建......
  • 2024-2025-1 20241411王思棋《计算机基础与程序设计》第十周学习总结
    作业信息|这个作业属于哪个课程|https://edu.cnblogs.com/campus/besti/2024-2025-1-CFAP||-- |-- ||这个作业要求在哪里|https://www.cnblogs.com/rocedu/p/9577842.html#WEEK10||这个作业的目标|信息系统、数据库与SQL、人工智能与专家系统、人工神经网络、模拟与离散事件......
  • 20241313 刘鸣宇 《计算机基础与程序设计》第十周学习总结
    2024-2025-120241313《计算机基础与程序设计》第十周学习总结作业信息这个作业属于哪个课程<班级的链接>(如2024-2025-1-计算机基础与程序设计)这个作业要求在哪里<作业要求的链接>(如2024-2025-1计算机基础与程序设计第一周作业)这个作业的目标<写上具体方面>......