CCF CSP 第36次(2024.12)(1_移动_C++)

CCF CSP 第36次(2024.12)(1_移动_C++)

时间限制 : 1.0 秒
空间限制 : 512 MiB
原题链接

解题思路:

思路一:

1、解题步骤拆分:

① 数据输入:

  • 第一行输入 n(int) 和 k(int) (n代表实验场地的大小,k代表查询个数)
  • 接下来k行每行包含三个数据 x(int) y(int) str(string) ,x 和 y为机器人的初始位置,str为机器人的指令序列(fblr)

② 数据处理:

对x y进行相应的变换 (注意超出场地大小则不移动)

  • 向前移动 f
  • 向后移动 b
  • 向左移动 l
  • 向右移动 r

③ 数据输出:输出最终机器人所处场地的位置

代码实现

代码实现(思路一):
cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

int main(int argc, char const *argv[])
{
    int n, k;
    cin >> n >> k;  // 输入实验场地的大小 n 和查询的次数 k

    int x, y;
    string str;
    // 不需要一开始就初始化 ans 数组的大小,后续使用 push_back 添加数据
    vector<vector<int>> ans;  // 用于存储每个查询的结果(每次机器人的最终位置)

    // 处理每个查询
    for (int i = 0; i < k; i++) {
        cin >> x >> y >> str;  // 输入机器人初始位置 (x, y) 和指令序列 str
        
        // 对每个指令进行处理
        for (char &s : str) {
            if (s == 'f' && y < n) y += 1;  // 'f' 表示向前移动,且不能超过场地的上限
            if (s == 'b' && y > 1) y -= 1;  // 'b' 表示向后移动,且不能低于场地的下限
            if (s == 'l' && x > 1) x -= 1;  // 'l' 表示向左移动,且不能低于场地的下限
            if (s == 'r' && x < n) x += 1;  // 'r' 表示向右移动,且不能超过场地的上限
        }
        
        // 将机器人的最终位置加入 ans 数组
        ans.push_back({x, y});
    }

    // 输出每个查询后机器人的最终位置
    for (int i = 0; i < k; i++) {
        cout << ans[i][0] << " " << ans[i][1] << endl;  // 输出第 i 个查询的最终位置
    }

    return 0;
}

欢迎大家和我沟通交流(✿◠‿◠)

相关推荐
No0d1es5 小时前
2025年 CSP-J1 入门级初赛 C++真题
开发语言·c++·青少年编程·csp·信息学奥赛·初赛
橙子也要努力变强5 小时前
C++中的多态
c++
ysa0510305 小时前
虚拟位置映射(标签鸽
数据结构·c++·笔记·算法
m0_748248026 小时前
C++中的位运算符:与、或、异或详解
java·c++·算法
草莓熊Lotso7 小时前
C++ 方向 Web 自动化测试实战:以博客系统为例,从用例到报告全流程解析
前端·网络·c++·人工智能·后端·python·功能测试
共享家95277 小时前
LRU 缓存的设计与实现
开发语言·c++
草莓熊Lotso8 小时前
Linux 基础开发工具入门:软件包管理器的全方位实操指南
linux·运维·服务器·c++·人工智能·网络协议·rpc
小龙报8 小时前
算法通关指南:数据结构和算法篇 --- 队列相关算法题》--- 1. 【模板】队列,2. 机器翻译
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
晨非辰8 小时前
【数据结构初阶】--从排序算法原理分析到代码实现操作,参透插入排序的奥秘!
c语言·开发语言·数据结构·c++·算法·面试·排序算法
2301_7951672012 小时前
玩转Rust高级应用 如何避免对空指针做“解引用”操作,在C/C++ 里面就是未定义行为
c语言·c++·rust