poj 1835 宇航员
http://poj.org/problem?id=1835
| Time Limit: 2000MS | Memory Limit: 30000K | |
| Total Submissions: 4802 | Accepted: 2058 |
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
Output
Sample Input
1
6
left 10
right 11
up 12
down 13
forward 14
back 15
Sample Output
23 -10 12 3
Source
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<queue>
#include<iostream>
#include<stack>
#include<map>
#include<string>
using namespace std;
int main(){
char ch[];
int n, t, tcase;
scanf("%d", &tcase);
while(tcase--){
scanf("%d", &n);
int face, head, x, y, z, num;
x = y = z = face = ;
head = ;
for(int i = ; i < n; i++){
scanf("%s%d", ch, &num);
if(ch[] == 'f'){
if(face == ) x += num;
if(face == ) y += num;
if(face == ) z += num;
if(face == ) x -= num;
if(face == ) y -= num;
if(face == ) z -= num;
}
else if(ch[] == 'b'){
face = (face+)%;
if(face == ) x += num;
if(face == ) y += num;
if(face == ) z += num;
if(face == ) x -= num;
if(face == ) y -= num;
if(face == ) z -= num;
}
else if(ch[] == 'l'){
if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; if(face == ) x += num;
if(face == ) y += num;
if(face == ) z += num;
if(face == ) x -= num;
if(face == ) y -= num;
if(face == ) z -= num;
}
else if(ch[] == 'r'){
if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ;
else if(face == && head == ) face = ; if(face == ) x += num;
if(face == ) y += num;
if(face == ) z += num;
if(face == ) x -= num;
if(face == ) y -= num;
if(face == ) z -= num;
}
else if(ch[] == 'u'){
t = face;
face = head;
head = (t+)%;
if(face == ) x += num;
if(face == ) y += num;
if(face == ) z += num;
if(face == ) x -= num;
if(face == ) y -= num;
if(face == ) z -= num;
}
else if(ch[] == 'd'){
t = face;
face = (head+)%;
head = t;
if(face == ) x += num;
if(face == ) y += num;
if(face == ) z += num;
if(face == ) x -= num;
if(face == ) y -= num;
if(face == ) z -= num;
}
//printf("%d %d %d %d %d\n", x, y, z, face, head);
}
printf("%d %d %d %d\n", x, y, z, face);
}
return ;
}
poj 1835 宇航员的更多相关文章
- POJ - 1835 宇航员(模拟题)
问题描述: 宇航员在太空中迷失了方向,在他的起始位置现在建立一个虚拟xyz坐标系,称为绝对坐标系,宇航员正面的方向为x轴正方向,头顶方向为z轴正方向,则宇航员的初始状态如下图所示: 现对六个方向分别标 ...
- POJ 题目分类(转载)
Log 2016-3-21 网上找的POJ分类,来源已经不清楚了.百度能百度到一大把.贴一份在博客上,鞭策自己刷题,不能偷懒!! 初期: 一.基本算法: (1)枚举. (poj1753,poj2965 ...
- (转)POJ题目分类
初期:一.基本算法: (1)枚举. (poj1753,poj2965) (2)贪心(poj1328,poj2109,poj2586) (3)递归和分治法. (4)递推. ...
- poj分类
初期: 一.基本算法: (1)枚举. (poj1753,poj2965) (2)贪心(poj1328,poj2109,poj2586) (3)递归和分治法. ( ...
- poj 题目分类(1)
poj 题目分类 按照ac的代码长度分类(主要参考最短代码和自己写的代码) 短代码:0.01K--0.50K:中短代码:0.51K--1.00K:中等代码量:1.01K--2.00K:长代码:2.01 ...
- POJ题目分类(按初级\中级\高级等分类,有助于大家根据个人情况学习)
本文来自:http://www.cppblog.com/snowshine09/archive/2011/08/02/152272.spx 多版本的POJ分类 流传最广的一种分类: 初期: 一.基本算 ...
- POJ题目分类(转)
初期:一.基本算法: (1)枚举. (poj1753,poj2965) (2)贪心(poj1328,poj2109,poj2586) (3)递归和分治法. (4)递推. ...
- POJ题目细究
acm之pku题目分类 对ACM有兴趣的同学们可以看看 DP: 1011 NTA 简单题 1013 Great Equipment 简单题 102 ...
- POJ题目(转)
http://www.cnblogs.com/kuangbin/archive/2011/07/29/2120667.html 初期:一.基本算法: (1)枚举. (poj1753,poj29 ...
随机推荐
- 向nginx发送reopen信号以重新打开日志文件
先移动日志文件 mv /usr/local/openresty/nginx/logs/access.log /usr/local/openresty/nginx/logs/access.log.201 ...
- HTML结构化
目的:为开发页面时有一套明确的页面结构化实施方案,提高开发效率: HTML结构化指的其实就是使用HTML语义化标签根据web标准书写具有明确结构逻辑的HTML代码的一种思路: 说白了重点就是:页面实际 ...
- CentOS7 编译安装 Mariadb (实测 笔记 Centos 7.0 + Mariadb 10.0.15)
环境: 系统硬件:vmware vsphere (CPU:2*4核,内存2G,双网卡) 系统版本:CentOS-7.0-1406-x86_64-DVD.iso 安装步骤: 1.准备 1.1 显示系统版 ...
- Python之路第一课Day3--随堂笔记(文件操作)
一.集合的介绍 1.集合操作 集合是一个无序的,不重复的数据组合,它的主要作用如下: 去重,把一个列表变成集合,就自动去重了 关系测试,测试两组数据之前的交集.差集.并集等关系 常用操作 s = se ...
- HDU2653 BFS+优先队列
Waiting ten thousand years for Love Time Limit: 10000/2000 MS (Java/Others) Memory Limit: 32768/3 ...
- jquery 时间戳与日期转换
(function($) { $.extend({ myTime: { /** * 当前时间戳 * @return <int> unix时间戳(秒) */ CurTime: functio ...
- IIS7应用程序池集成和经典的区别
IIS7应用程序池集成和经典的区别 IIS7应用程序池有集成和经典两种模式,根据微软官方的介绍, 集成模式,如果托管应用程序在采用集成模式的应用程序池中运行,服务器将使用 IIS 和 ASP.NET ...
- 面试习题之设计模式 C#观察者模式(猫叫老鼠惊走主人醒)
腾讯云测试|TEST Tencent Cloud /* * CatShout.cs */ using System; using System.IO; using System.Collections ...
- 返回数据方法DeaCacheCommand,由CRL自动实现
越来越多的人学起了前端,或许部分的初衷仅是它简单易上手以及好找工作,毕竟几年前只会个html和css就能有工作,悄悄告诉泥萌,这也是博主一年前的初衷 还好numpy, scikit-learn都提供了 ...
- 【7集iCore3基础视频】7-6 Quartus II 13.1安装
Quartus II 13.1安装:高清源视频:链接:http://pan.baidu.com/s/1csVRMA 密码:lkth 视频勘误:http://pan.baidu.com/s/1mhCIq ...