Programming a robot
题目链接:Gym - 101492H
自己的纯暴力做法:
- /* */
- # include <iostream>
- # include <cstdio>
- # include <cstring>
- # include <string>
- # include <cstdlib>
- # include <cmath>
- # include <ctime>
- # include <climits>
- # include <memory>
- # include <functional>
- # include <algorithm>
- # include <bitset>
- # include <set>
- # include <map>
- # include <stack>
- # include <vector>
- # include <deque>
- # include <queue>
- # include <iomanip>
- # include <utility>
- using namespace std;
- # define lson l,m,rt<<
- # define rson r,m+,rt<<|
- # define lowbit(x) (x&(-x))
- # define lcm(a,b) (a*b/__gcd(a,b))
- typedef long long ll;
- const ll mod=1e9+;
- const int maxn=;
- const double pi=acos(-1.0);
- const int eps=1e-;
- int main()
- {
- char c;
- ll x0, y0, xd, yd;
- int flag1=-, flag2=-;
- scanf("%lld %lld %c", &x0, &y0, &c);
- scanf("%lld %lld", &xd, &yd);
- ll x=xd-x0;
- ll y=yd-y0;
- if( x== && y== )//在原位
- {
- printf("0\n");
- }
- else if( x== && y> )//在上方
- {
- if( c=='N' )
- {
- //printf("%lld\n", y);
- printf("1\n");
- printf("A %lld\n", y);
- }
- else if( c=='E' )
- {
- printf("%d\n", +);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", y);
- }
- else if( c=='S' )
- {
- printf("%d\n", +);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", y);
- }
- else if( c=='O')
- {
- printf("%d\n", +);
- printf("D\n");
- printf("A %lld\n", y);
- }
- }
- else if( x== && y< )//在下方
- {
- y = -y;
- if( c=='S')
- {
- printf("1\n");
- printf("A %lld\n", y);
- }
- else if( c=='E' )
- {
- printf("%d\n", +);
- printf("D\n");
- printf("A %lld\n", y);
- }
- else if( c=='N' )
- {
- printf("%d\n", +);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", y);
- }
- else if( c=='O' )
- {
- printf("%d\n", +);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", y);
- }
- }
- else if( x> && y== )//在右边
- {
- if( c=='E' )
- {
- printf("1\n");
- printf("A %lld\n", x);
- }
- else if( c=='S' )
- {
- printf("%d\n", +);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", x);
- }
- else if( c=='O' )
- {
- printf("%d\n", +);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", x);
- }
- else if( c=='N' )
- {
- printf("%d\n", +);
- printf("D\n");
- printf("A %lld\n", x);
- }
- }
- else if(x< && y== )//在左边
- {
- x=-x;
- if( c=='O' )
- {
- printf("1\n");
- printf("A %lld\n", x);
- }
- else if( c=='N' )
- {
- printf("%d\n", +);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", x);
- }
- else if( c=='E' )
- {
- printf("%d\n", +);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", x);
- }
- else if( c=='S' )
- {
- printf("%d\n", +);
- printf("D\n");
- printf("A %lld\n", x);
- }
- }
- else if( x> && y> )//在右上方
- {
- if( c=='N' )
- {
- printf("%d\n", ++);
- printf("A %lld\n", y);
- printf("D\n");
- printf("A %lld\n", x);
- }
- else if( c=='E' )
- {
- printf("%d\n", ++);
- printf("A %lld\n", x);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", y);
- }
- else if( c=='S' )
- {
- printf("%d\n", +++);
- printf("D\n");
- printf("D\n");
- printf("A %lld\n", y);
- printf("D\n");
- printf("A %lld\n", x);
- }
- else if( c=='O')
- {
- printf("%d\n", +++);
- printf("D\n");
- printf("A %lld\n", y);
- printf("D\n");
- printf("A %lld\n", x);
- }
- }
- else if( x> && y< )//在右下
- {
- y=-y;
- if( c=='S' )
- {
- printf("%d\n", ++);
- printf("A %lld\n", y);
- for(int i=; i<; i++ )
- {
- printf("D\n");
- }
- printf("A %lld\n", x);
- }
- if( c=='O')
- {
- printf("%d\n", +++);
- printf("D\nD\n");
- printf("A %lld\n", x);
- printf("D\n");
- printf("A %lld\n", y);
- }
- if( c=='N' )
- {
- printf("%d\n", +++);
- printf("D\n");
- printf("A %lld\n", x);
- printf("D\n");
- printf("A %lld\n", y);
- }
- if( c=='E' )
- {
- printf("%d\n", ++);
- printf("A %lld\n", x);
- printf("D\n");
- printf("A %lld\n", y);
- }
- }
- else if( x< && y< )
- {
- x = -x;
- y = -y;
- if( c=='S' )
- {
- printf("%d\n", ++);
- printf("A %lld\n", y);
- printf("D\n");
- printf("A %lld\n", x);
- }
- if( c=='O' )
- {
- printf("%d\n", ++);
- printf("A %lld\n", x);
- printf("D\nD\nD\n");
- printf("A %lld\n", y);
- }
- if( c=='N' )
- {
- printf("%d\n", +++);
- printf("D\nD\n");
- printf("A %lld\n", y);
- printf("D\n");
- printf("A %lld\n", x);
- }
- if( c=='E' )
- {
- printf("%d\n", +++);
- printf("D\n");
- printf("A %lld\n", y);
- printf("D\n");
- printf("A %lld\n", x);
- }
- }
- else if( x< && y> )//在左上
- {
- x=-x;
- if( c=='N' )
- {
- printf("%d\n", ++);
- printf("A %lld\n", y);
- printf("D\nD\nD\n");
- printf("A %lld\n", x);
- }
- if( c=='E' )
- {
- printf("%d\n", +++);
- printf("D\nD\n");
- printf("A %lld\n", x);
- printf("D\n");
- printf("A %lld\n", y);
- }
- if( c=='S' )
- {
- printf("%d\n", +++);
- printf("D\n");
- printf("A %lld\n", x);
- printf("D\n");
- printf("A %lld\n", y);
- }
- if( c=='O' )
- {
- printf("%d\n", ++);
- printf("A %lld\n", x);
- printf("D\n");
- printf("A %lld\n", y);
- }
- }
- return ;
- }
后来看别人的代码才知道“模拟”
- /* */
- # include <iostream>
- # include <cstdio>
- # include <cstring>
- # include <string>
- # include <cstdlib>
- # include <cmath>
- # include <ctime>
- # include <climits>
- # include <memory>
- # include <functional>
- # include <algorithm>
- # include <bitset>
- # include <set>
- # include <map>
- # include <stack>
- # include <vector>
- # include <deque>
- # include <queue>
- # include <iomanip>
- # include <utility>
- using namespace std;
- # define lson l,m,rt<<
- # define rson r,m+,rt<<|
- # define lowbit(x) (x&(-x))
- # define lcm(a,b) (a*b/__gcd(a,b))
- typedef long long ll;
- const ll mod=1e9+;
- const int maxn=;
- const double pi=acos(-1.0);
- const int eps=1e-;
- char s[]={'N', 'E', 'S', 'O', 'N', 'E', 'S'};
- int _find(char c, int k)
- {
- for(int i=; s[i]!='\0'; i++ )
- if( s[i]==c && i>=k )
- return i;
- }
- int main()
- {
- int a, b, x, y;
- char m, n, c;
- while( cin>>x>>y>>c>>a>>b )
- {
- int k1=_find(c, ), k2, k3;
- if( a==x )
- k2=;
- if( b==y )
- k3=;
- if( a!=x && b!=y )
- {
- if( a>x )//右
- {
- m='E';
- if( b>y )//上
- n='N';
- else if( b<y )//下
- n='S';
- }
- else if( a<x )//左
- {
- m='O';
- if( b>y )//上
- n='N';
- else if( b<y )//下
- n='S';
- }
- k2 = _find(n, k1)-k1;
- k3 = _find(m, k1)-k1;
- cout<<max(k2, k3)+<<endl;//max(k2,k3)是求一定要转够的书,2是两次直走步骤
- int px=fabs(x-a);
- int py=fabs(y-b);
- if( k2>k3 )
- {
- for(int i=; i<k3; i++ )
- {
- cout<<"D"<<endl;//转到要转的方向才可以走
- }
- cout<<"A "<<px<<endl;
- for(int i=k3; i<k2; i++ )
- cout<<"D"<<endl;
- cout<<"A "<<py<<endl;
- }
- else
- {
- for(int i=; i<k2; i++ )
- cout<<"D"<<endl;
- cout<<"A "<<py<<endl;
- for(int i=k2; i<k3; i++ )
- cout<<"D"<<endl;
- cout<<"A "<<px<<endl;
- }
- }
- else
- {
- if( x==a&&y==b )
- cout<<<<endl;
- else if( x==a )
- {
- if( b>y )//正上方
- n='N';
- else//正下方
- n='S';
- k2=_find(n, k1)-k1;
- cout<<k2+<<endl;
- for(int i=; i<k2; i++ )
- cout<<"D"<<endl;
- cout<<"A "<<fabs(b-y)<<endl;
- }
- else if( y==b )
- {
- if( a>x )
- m='E';
- else
- m='O';
- k3=_find(m,k1)-k1;
- cout<<k3+<<endl;
- for(int i=; i<k3; i++ )
- cout<<"D"<<endl;
- cout<<"A "<<fabs(a-x)<<endl;
- }
- }
- }
- return ;
- }
Programming a robot的更多相关文章
- Robot Framework 快速入门_英文版
Copyright © Nokia Siemens Networks 2008 Licensed under the Apache License, Version 2.0 Table of Cont ...
- (一)ROS系统入门 Getting Started with ROS 以Kinetic为主更新 附课件PPT
ROS机器人程序设计(原书第2版)补充资料 教案1 ROS Kinetic系统入门 ROS Kinetic在Ubuntu 16.04.01 安装可参考:http://blog.csdn.net/zha ...
- MRPT - Mobile Robot Programming Toolkit
1. https://www.mrpt.org/Building_and_Installing_Instructions#1_Prerequisites P1. error C2371: “int32 ...
- Mujin Programming Challenge 2017A - Robot Racing【思维题】
题意: 给你n个人的位置,每个人能往后跳一格或两格到无人的位置,跳到0位置,这个人消失,n个人消失组成一个排列,问有多少种排列. 思路: 额,搞了一整场这个A...代码也巨挫了. 处理成1,3,5,7 ...
- Learning ROS for Robotics Programming - Second Edition(《学习ROS机器人编程-第二版》)
Learning ROS for Robotics Programming - Second Edition <学习ROS机器人编程-第二版> ----Your one-stop guid ...
- CSUFT 1002 Robot Navigation
1002: Robot Navigation Time Limit: 1 Sec Memory Limit: 128 MB Submit: 4 Solved: 2 Descript ...
- [LeetCode] 63. Unique Paths II_ Medium tag: Dynamic Programming
A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...
- Robot Framework - 一些练习
01 - 安装Robot Framework TA环境 根据系统请选择对应的版本包来安装,下面是以Win7-64bit系统为例,来说明如何搭建一个可以运行练习三test case的RF TA环境. 1 ...
- [LeetCode] 62. Unique Paths_ Medium tag: Dynamic Programming
A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...
随机推荐
- java之mybatis之使用mybatis实现crud操作
目录结构: 1.封装 mybatis 的工具类: MybatisUtil.java public class MybatisUtil { private static SqlSessionFactor ...
- AWS--Lamdba
分享一个Lambda相关的连接 https://blog.csdn.net/m0_37204491/article/details/72829477
- HashMap的内部结构与hash冲突
HashMap的内部结构 HashMap简介: HashMap继承AbstractMap,AbstractMap实现Map接口 HashMap是线程不同步的,线程不安全的 HashMap可以把null ...
- BFC特性及其简单应用
BFC是什么? BFC(Block Formatting Context)中文直译就是‘块级格式上下文’,它是 W3C CSS 2.1 规范中的一个概念,它决定了元素如何对其内容进行定位,以及与其他元 ...
- JavaScript之控制标签属性
var pic=document.getElementById('pic'); var obtn=document.getElementById('btn'); console.log(pic.get ...
- docker实战 (3) 常规配置
本节会持续更新,在项目实战中遇到的docker配置都会更新进来 docker常用命令: docker 介绍: what: 是什么 why: 为什么用 how: 怎么用 docker 特点: 轻量级,可 ...
- requests中构造post请求注意点
构造post请求时需要注意点: 通过requests.post()进行POST请求时,传入报文的参数有两个,一个是data,一个是json. 如果是urlencoded 格式 data=字典如果是js ...
- 浅谈HDFS(三)之DataNote
DataNode工作机制 一个数据块在DataNode上以文件形式存储在磁盘上,包括两个文件,一个是数据本身,一个是元数据包括数据块的长度,块数据的校验和,以及时间戳. DataNode启动后向Nam ...
- Java开发环境之JDK
查看更多Java开发环境配置,请点击<Java开发环境配置大全> 零章:JDK安装教程 1)下载JDK安装包 http://www.oracle.com/technetwork/java/ ...
- 如何临时修改 macOS 应用的界面语言?
一般情况下,应用程序的界面语言会和系统语言保持一致.但有些时候,我们也会希望临时换用一种不同的界面语言.例如,一些程序的中文翻译词不达意,有必要参考英文界面来确定功能的准确含义:又如,一些网页会强制按 ...