• P0J-1835-宇航员-模拟(1)


    宇航员
    Time Limit: 2000MS   Memory Limit: 30000K
    Total Submissions: 4866   Accepted: 2077

    Description

    问题描述:
      宇航员在太空中迷失了方向,在他的起始位置现在建立一个虚拟xyz坐标系,称为绝对坐标系,宇航员正面的方向为x轴正方向,头顶方向为z轴正方向,则宇航员的初始状态如下图所示:

    现对六个方向分别标号,x,y,z正方向分别为0,1,2,负方向分别为3,4,5;称它们为绝对方向。宇航员在宇宙中只沿着与绝对坐标系xyz轴平行的方向行走,但是他不知道自己当前绝对坐标和自己面向的绝对方向。

    任务描述:
      请根据宇航员对自己在相对方向上移动的描述确定宇航员最终的绝对坐标和面向的绝对方向。对在相对方向上移动的描述及意义如下:
    forward x  向前走x米。
    back x 先转向后,再走x米。
    left x 先转向左,再走x米。
    right x 先转向右,再走x米。
    up x 先面向上,再走x米。
    down x 先面向下,再走x米。
    其中向上和向下如下图所示:

    Input

    第一行一个正整数m,表示测试数据的组数。每组测试数据第一行是一个正整数n(1<=n<=10000)表示宇航员行走的次数,下面n行每行输入一次相对行走,格式如上所述,其中( 1 <= x <= 10000 为正整数)。

    Output

    对于每组输入数据输出一行,x y z p, 中间用空格隔开,x y z是宇航员的位置的绝对坐标,p是宇航员面向的绝对方向编号(0<=p <=5)。

    Sample Input

    1
    6
    left 10
    right 11
    up 12
    down 13
    forward 14
    back 15
    

    Sample Output

    23 -10 12 3

    Source



    思路:先表示出初始状态,正面=0,左面=4,上面=2,随着坐标的变化,这三个面的相对关系也跟随着变化
    #include<stdio.h>
    int main()
    {
        int n,i;
        scanf("%d",&n);
        while(n--)
        {
            char str[11];
            int face=0,left=4,head=2,temp,x=0,y=0,z=0,d,m;
            scanf("%d",&m);
            for(i=0;i<m;i++)
            {
                scanf("%s%d",str,&d);
                if(str[0]=='b')
                 {
                     face=(face+3)%6;//加3在对6取余就是这个方向的相反方向。
                     left=(left+3)%6;
                 }
                 else if(str[0]=='l')
                 {
                     temp=face;
                     face=left;
                     left=(temp+3)%6;
                 }
                 else if(str[0]=='r')
                 {
                     temp=left;
                     left=face;
                     face=(temp+3)%6;
                 }
                 else if(str[0]=='u')
                 {
                     temp=face;
                     face=head;
                     head=(temp+3)%6;
                 }
                 else if(str[0]=='d')
                 {
                     temp=head;
                     head=face;
                     face=(temp+3)%6;
                 }
                 if(face==0)
                    x+=d;
                 if(face==1)
                    y+=d;
                 if(face==2)
                    z+=d;
                 if(face==3)
                    x-=d;
                 if(face==4)
                    y-=d;
                 if(face==5)
                    z-=d;
            }
            printf("%d %d %d %d
    ",x,y,z,face);
        }
    
    }
  • 相关阅读:
    npm install node-echarts npm ERR! code ELIFECYCLE
    MySql-Proxy之多路结果集归并
    Error: Cannot find module 'is-accessor-descriptor'
    如何在Node.js实现兼容ES6
    perl 自动识别编码,转换编码
    Mixin result declared without body
    Python爬虫入门教程 48-100 使用mitmdump抓取手机惠农APP-手机APP爬虫部分
    unexpected token "indent"
    Radware:上周五美国大规模DDoS攻击是如何发生的
    Radware:上周五美国大规模DDoS攻击是如何发生的
  • 原文地址:https://www.cnblogs.com/tianmin123/p/4626412.html
Copyright © 2020-2023  润新知