文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

CCF-CSP真题《202309-1 坐标变换(其一)》思路+python,c++,java满分题解

2023-10-11 21:27

关注

想查看其他题的真题及题解的同学可以前往查看:CCF-CSP真题附题解大全


试题编号: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 个操作后的位置。

样例输入

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。

真题来源:坐标变换(其一)

 感兴趣的同学可以如此编码进去进行练习提交

python题解: 

n, m = map(int,input().split())temp_x = temp_y = 0for i in range(n):    x1, y1 = map(int, input().split())    temp_x += x1    temp_y += y1for i in range(m):    x, y = map(int, input().split())    x += temp_x    y += temp_y    print('{} {}'.format(x,y))

运行结果:


c++满分题解:

#include 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;}

 运行结果:


 Java满分题解:

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯