问题描述
对于平面直角坐标系上的坐标 (x,y),小 P 定义了一个包含 n 个操作的序列T=(t1,t2,....tn)。其中每个操作 ti(1<=i<=n)包含两个参数dx和 dy,表示将坐标 (x,y) 平移至 (x+dx.y+dy) 处。
现给定 m 个初始坐标,试计算对每个坐标 (xj,yj)(1≤j≤m)依次进行 T 中 n 个操作后的最终坐标。
输入格式
从标准输入读入数据。
输入共 n+m+1 行。
输入的第一行包含空格分隔的两个正整数 n 和 m,分别表示操作和初始坐标个数。
接下来 n行依次输入 n 个操作,其中第 i(1≤i≤n)行包含空格分隔的两个整数 dx,dy。
接下来 m 行依次输入 m个坐标,其中第 j(1≤j≤m)行包含空格分隔的两个整数 xj、yj。
输出格式
输出到标准输出中。
输出共 m 行,其中第 j(1≤j≤m)行包含空格分隔的两个整数,表示初始坐标 (xj,yj) 经过 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)。
评测用例规模与约定
全部的测试数据满足:n,m≤100,所有输入数据(x,y,dx,dy)均为整数且绝对值不超过 100000。
题目分析
对于输入m个坐标没有什么优化,主要注意优化n个操作。
对于每一个输入坐标都要进行一次操作序列,但是操作序列是给定的规则,即都是平移,那么就是在原坐标的基础上一直对应相加n个操作序列。
一种想法是嵌套循环,对于m中的每一个坐标依次遍历相加n个操作序列,时间复杂度为O(n2)。
但是还有一种不需要嵌套的方法,因为初始坐标要相加 n个操作,所以可以在输入n个操作时先把操作相加,最后再和初始坐标相加,这样避免了嵌套,时间复杂度为O(n)。
代码示例
以下输入坐标形式为结构体,存储在vector中。
#include<iostream>
#include<vector>
using namespace std;
typedef struct xy {
int x;
int y;
}xy;
int main() {
int n = 0, m = 0;//操作 初始坐标个数
cin >> n >> m;
xy tmp;
xy ope={ 0,0 };
vector<xy> dm;
int i = 0;
for ( i = 0; i < n; i++)
{
cin >> tmp.x >> tmp.y;
ope.x += tmp.x;
ope.y += tmp.y;
}
for ( i = 0; i < m; i++)
{
cin >> tmp.x >> tmp.y;
dm.push_back(tmp);
}
for (i = 0; i < m; i++)
{
dm[i].x += ope.x;
dm[i].y += ope.y;
cout << dm[i].x << " " << dm[i].y << endl;
}
return 0;
}