试题编号: | 202309-1 |
试题名称: | 坐标变换(其一) |
时间限制: | 1.0s |
内存限制: | 512.0MB |
问题描述: |
问题描述对于平面直角坐标系上的坐标 (x,y),小 P 定义了一个包含 n 个操作的序列 T=(t1,t2,⋯,tn)。其中每个操作 ti(1≤i≤n)包含两个参数 dxi 和 dyi,表示将坐标 (x,y) 平移至 (x+dxi,y+dyi) 处。 现给定 m 个初始坐标,试计算对每个坐标 (xj,yj)(1≤j≤m)依次进行 T 中 n 个操作后的最终坐标。 输入格式输入共 n+m+1 行。 输入的第一行包含空格分隔的两个正整数 n 和 m,分别表示操作和初始坐标个数。 接下来 n 行依次输入 n 个操作,其中第 i(1≤i≤n)行包含空格分隔的两个整数 dxi、dyi。 接下来 m 行依次输入 m 个坐标,其中第 j(1≤j≤m)行包含空格分隔的两个整数 xj、yj。 输出格式输出共 m 行,其中第 j(1≤j≤m)行包含空格分隔的两个整数,表示初始坐标 (xj,yj) 经过 n 个操作后的位置。 样例输入
样例输出
样例说明第一个坐标 (1,−1) 经过三次操作后变为 (21,−11);第二个坐标 (0,0) 经过三次操作后变为 (20,−10)。 评测用例规模与约定 |
n, m = map(int,input().split())
temp_x = temp_y = 0
for i in range(n):
x1, y1 = map(int, input().split())
temp_x += x1
temp_y += y1
for i in range(m):
x, y = map(int, input().split())
x += temp_x
y += temp_y
print('{} {}'.format(x,y))
c++满分题解:
#include <bits/stdc++.h>
using namespace std;
int n, m;
int temp_x=0, temp_y=0;
int x, y;
int main()
{
cin >> n >> m;
for (int i = 0; i < n; i++)
{
cin >> x >> y;
temp_x += x;
temp_y += y;
}
for (int i = 0; i < m; i++)
{
cin >> x >> y;
x += temp_x;
y += temp_y;
cout << x <<" "<< y << "n";
}
cout << endl;
return 0;
}
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int m = in.nextInt();
int temp_x = 0;
int temp_y = 0;
for( int i = 1; i <= n; i++ ) {
int x = in.nextInt();
int y = in.nextInt();
temp_x += x;
temp_y += y;
}
for( int i = 1; i <= m; i++ ) {
int x = in.nextInt();
int y = in.nextInt();
x += temp_x;
y += temp_y;
System.out.println(x+" "+y);
}
}
}
原文地址:https://blog.csdn.net/weixin_53919192/article/details/133274096
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_14601.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。