csp202309-2 坐标变换(其二)(80)超时

试题编号:202309-2
试题名称:坐标变换(其二)
时间限制:2.0s
内存限制:512.0MB
问题描述:

问题描述

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

  1. 拉伸 � 倍:横坐标 � 变为 ��,纵坐标 � 变为 ��;

  2. 旋转 �:将坐标 (�,�) 绕坐标原点 (0,0) 逆时针旋转 � 弧度(0≤�<2�)。易知旋转后的横坐标为 �cos⁡�−�sin⁡�,纵坐标为 �sin⁡�+�cos⁡�。

设定好了包含 � 个操作的序列 (�1,�2,⋯,��) 后,小 P 又定义了如下查询:

  • i j x y:坐标 (�,�) 经过操作 ��,⋯,��(1≤�≤�≤�)后的新坐标。

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

输入格式

从标准输入读入数据。

输入共 �+�+1 行。

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

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

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

输出格式

输出到标准输出中。

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

样例输入

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

Data

样例输出

-1858706.758 -83259.993
-1261428.46 201113.678
-75099.123 -738950.159
-119179.897 -789457.532
114151.88 -366009.892

代码

#include <iostream>
#include <math.h>
using namespace std;
int main(){
    int n,m;cin>>n>>m;
    double b[n][2];
    for (int i = 0; i < n; i++)
    {
        cin>>b[i][0];
        cin>>b[i][1];
    }
    for (int i = 0; i < m; i++)//m个坐标
    {
        double first=0,end=0,x1=0,y1=0,x2=0,y2=0;
        cin>>first>>end>>x1>>y1;
        for(int j=first-1;j<end;j++){//first-end操作
            if(b[j][0]==1){
                x1=x1*b[j][1];
                y1=y1*b[j][1];
            }
            if(b[j][0]==2){
                x2=x1;y2=y1;
                x1=x2*cos(b[j][1])-y2*sin(b[j][1]);
                y1=x2*sin(b[j][1])+y2*cos(b[j][1]);
            }
        }
        printf("%.2f",x1);
        cout<<" ";
        printf("%.2f",y1);
        cout<<endl;
    }
    return 0;
}

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值