zoukankan      html  css  js  c++  java
  • noip模拟赛 机器人

    题目描述

    早苗入手了最新的Gundam模型。最新款自然有着与以往不同的功能,那就是它能够自动行走,厉害吧。

    早苗的新模型可以按照输入的命令进行移动,命令包括‘E’、‘S’、‘W’、‘N’四种,分别对应东南西北。执行某个命令时,它会向对应方向移动一个单位。作为新型机器人,它可以执行命令串。对于输入的命令串,每一秒它会按命令行动一次。执行完命令串的最后一个命令后,会自动从头开始循环。在0时刻时机器人位于(0,0)。求T秒后机器人所在位置坐标。

    输入输出格式

    输入格式:

    第1行:一个字符串,表示早苗输入的命令串,保证至少有1个命令

    第2行:一个正整数T

    输出格式:

    2个整数,表示T秒时,机器人的坐标。

    输入输出样例

    输入样例#1:
    NSWWNSNEEWN
    12
    输出样例#1:
    -1 3

    说明

    对于60%的数据 T<=500,000 且命令串长度<=5,000

    对于100%的数据 T<=2,000,000,000 且命令串长度<=5,000

    【注意】

    向东移动,坐标改变改变为(X+1,Y);

    向南移动,坐标改变改变为(X,Y-1);

    向西移动,坐标改变改变为(X-1,Y);

    向北移动,坐标改变改变为(X,Y+1);

    分析:模拟.直接一位一位的模拟肯定是不行的,但是注意到每一个周期坐标的偏移量是一定的,所以看有多少个周期就好了.

    #include <cstdio>
    #include <iostream>
    #include <cstring>
    #include <vector>
    #include <algorithm>
    #include <string>
    
    using namespace std;
    
    string s;
    int T, x, y,tx,ty,s1,s2;
    
    int main()
    {
        cin >> s;
        scanf("%d", &T);
        for (int i = 0; i < s.size(); i++)
        {
            if (s[i] == 'N')
                ty++;
            if (s[i] == 'S')
                ty--;
            if (s[i] == 'W')
                tx--;
            if (s[i] == 'E')
                tx++;
        }
        s1 = T / s.size();
        s2 = T % s.size();
        x = tx * s1;
        y = ty * s1;
        for (int i = 0; i < s2; i++)
        {
            if (s[i] == 'N')
                y++;
            if (s[i] == 'S')
                y--;
            if (s[i] == 'W')
                x--;
            if (s[i] == 'E')
                x++;
        }
        printf("%d %d
    ", x, y);
    
        return 0;
    }
  • 相关阅读:
    设计模式学习笔记-观察者模式(转)
    VC++ 遍历文件夹
    VC++文件监控 ReadDirectoryChangesW
    Windows Socket五种I/O模型——代码全攻略(转)
    CentOS 6 安装RabbitMQ
    nginx tomcat负载配置
    Centos6 Nginx安装
    windows 安装MongoDB服务
    跟导师请教后写出的关于C#导出Excel,不导出隐藏列的方法
    linux 常用命令(四)——(centos7-centos6.8)Vim安装
  • 原文地址:https://www.cnblogs.com/zbtrs/p/7537003.html
Copyright © 2011-2022 走看看