【CSP】202309-1 坐标变换(其一)

2023年 第31次CCF计算机软件能力认证  202309-1 坐标变换(其一)

原题链接:坐标变换(其一)

时间限制: 1.0 秒

空间限制: 512 MiB

题目描述

对于平面直角坐标系上的坐标 (𝑥,𝑦),小 P 定义了一个包含 𝑛n 个操作的序列 𝑇=(𝑡1,𝑡2,⋯,𝑡𝑛)。其中每个操作 𝑡𝑖(1≤𝑖≤𝑛)包含两个参数 𝑑𝑥𝑖和 𝑑𝑦𝑖,表示将坐标 (𝑥,𝑦) 平移至 (𝑥+𝑑𝑥𝑖,𝑦+𝑑𝑦𝑖)处。

现给定 𝑚 个初始坐标,试计算对每个坐标 (𝑥𝑗,𝑦𝑗)(1≤𝑗≤𝑚)依次进行 𝑇 中 𝑛 个操作后的最终坐标。

输入格式

从标准输入读入数据。

输入共 𝑛+𝑚+1行。

输入的第一行包含空格分隔的两个正整数 𝑛 和 𝑚,分别表示操作和初始坐标个数。

接下来 𝑛 行依次输入 𝑛n 个操作,其中第 𝑖i(1≤𝑖≤𝑛)行包含空格分隔的两个整数 𝑑𝑥𝑖、𝑑𝑦𝑖​。

接下来 𝑚 行依次输入 𝑚 个坐标,其中第 𝑗(1≤𝑗≤𝑚)行包含空格分隔的两个整数 𝑥𝑗​、𝑦𝑗。

输出格式

输出到标准输出。

输出共 𝑚 行,其中第 𝑗(1≤𝑗≤𝑚)行包含空格分隔的两个整数,表示初始坐标 (𝑥𝑗,𝑦𝑗) 经过 𝑛n 个操作后的位置。

样例输入

3 2
10 10
0 0
10 -20
1 -1
0 0

样例输出

21 -11
20 -10

样例解释

第一个坐标 (1,−1) 经过三次操作后变为 (21,−11);第二个坐标 (0,0) 经过三次操作后变为 (20,−10)。

子任务

全部的测试数据满足:𝑛,𝑚≤100,所有输入数据(𝑥,𝑦,𝑑𝑥,𝑑𝑦)均为整数且绝对值不超过 10^5。

解题思路

把多行平移操作累计成一个总的平移操作。

AC代码

#include<bits/stdc++.h>

using namespace std;

const int N = 1e5 + 10;

int n, m;

int main()
{
    cin >> n >> m;
    int x, y, tx = 0, ty = 0;
    while(n --)
    {
        cin >> x >> y;
        tx += x, ty += y;
    }
    
    int x1, y1;
    while(m --)
    {
        cin >> x1 >> y1;
        cout << x1 + tx << " " << y1 + ty << endl;
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值