在校大学生,这个题觉得挺有意思的想分享一下思路,欢迎各位大佬指点。

题目要求

有一辆智能小车,最初(时间为0)的位置为(0,0),我们想知道它最后的位置。小车以每小时10公里的速度向北移动(以北为y轴正向,以东为x轴正向)。小车会受到一系列依照时间戳记排序的命令,1表示“向左转”,2表示“向右转”,3表“停止”。每个命令的前面有一个时间戳记,所以我们知道该命令是何时发出的。最后一个命令一定是“停止”。我们另外假设,这辆小车非常灵活,它可以在瞬间转弯。
以下列输入为例。小车在时间为5的时候收到一个“向左转”的命令1,在时间10收到一个“向右转”的命令2,在时间15收到一个“停止”的命令3。那么在最后时间15的时候,小车的位置将在(-50,100)。程序只要求输出小车最后的位置,第一个整数是x坐标,第二个整数是y坐标。

此题信息量大,考查内容较为综合。

(1)数字化。可为四个方向编号,自向北开始,逆时针将4个方向依次编号为0,1,2,3。当接到向左转命令,方向号增1,向右转则方向号减1。为避免出现负数或大于3的情况,可对4取模

代码如下(本人写的

#include <stdio.h>
#define speed 10
int main()
{
    int time,command;
    int x,y;
    int direct; direct=0;
    x=y=0;
    command=0;
    int differ;differ=0;
    int last;last=0;
    for (;command!=3;)
    {
        scanf("%d",&time);
        differ=time-last;
        last=time;
        start:
        switch (direct)
        {
            case 0:y+=speed*differ;break;
            case 1:x+=speed*differ;break;
            case 2:y-=speed*differ;break;
            case 3:x-=speed*differ;break;
            case 4:direct=0;goto start;break;
            case -1:direct=3;goto start;break;
        }
        scanf("%d",&command);
        if (command==1) direct--;
        if (command==2) direct++;
    }
    printf("%d %d",x,y);
}

说一下思路 根据提示可以设置个代表‘方向’的变量来控制小汽车的方向,然time 和command 为时间和命令

在这里我用0表示北方 1表示东方 2表示南方 3表示西方当然是顺时针因为比较好看(个人

所以在循环的最后输入command的值后,假设我第一次输入command的值为2,根据题目要求便是右转,因此在第一次输入后 北方变成了东方,由0-1正好为方向加一,再右转便是1-2正好对应的是南方,再一次就是东方。

可是这里发现问题了 如果我再把方向变量加一的话那么便是4了 而4没有对应的方向

同理一直往左转便是到-1也没有对应的方向,如何是好?

那么我们把对应的-1和4变成我们对应的数就行了

比如0-1为-1 对应的是东方变成西方 那西方对应的是3 那么把方向变量改成3不久可以了?4也是同样的道理因此 我在swich语句中专门检测了一个-1和一个4 等到其运算到-1和4时便用赋值语句将其重新赋值并用swich重新检测

这里我用的是swich语句由于方向有4个 因此swich很好对应,用if也是可以的

还有一个点是坐标的计算。

由于题目要求是先输入时间再输入命令因此第一次无论如何都是往北走的,方向设置为0就可以。第一次输入赋值time 此时往北走的时间正好就是time的值,但是再往后赋值time往其他方向走的便不是time的值了

举个例子 第一次time=5,往北走了5小时然后输入指令2转换成往东走

但是第二次time=10的时候往东走便是走了5个小时但是time等于10,因此往东走的时间不是time的值

显而易见第二次第三次等等走的是第2次到第3次的差值。因此可以赋值个变量differ来记录第n次到第n+1次输入时间的差值。 last表示第n次 time就是我们输入的第n+1次的值

如下

第一次输入 time=5 last=0因为没开始走

第二次输入time=10 last=5因为第一次输入的时间为5

differ=time-last

如下

differ=time-last;
        last=time;

然后就是前面的代码了

可能有点麻烦但是我觉得还行233

ZZULIOJ 1070小汽车的位置相关推荐

  1. ZZULIOJ 1070:小汽车的位置

    小汽车的位置 题目描述 有一辆智能小车,最初(时间为0)的位置为(0,0),我们想知道它最后的位置.小车以每小时10公里的速度向北移动(以北为y轴正向,以东为x轴正向).小车会受到一系列依照时间戳记排 ...

  2. 1070: 小汽车的位置 Python

    1070: 小汽车的位置 时间限制: 1 Sec 内存限制: 128 MB 提交: 16536 解决: 10981 [状态] [讨论版] [提交] [命题人:admin] 题目描述 有一辆智能小车,最 ...

  3. 1070: 小汽车的位置

    1070: 小汽车的位置 Time Limit: 1 Sec   Memory Limit: 128 MB Submit: 3279   Solved: 1904 Submit Status Web ...

  4. 【ZZULIOJ】1070: 小汽车的位置

    ZZULIOJ题解 1069: 向Z同学学习 题目描述 有一辆智能小车,最初(时间为0)的位置为(0,0),我们想知道它最后的位置.小车以每小时10公里的速度向北移动(以北为y轴正向,以东为x轴正向) ...

  5. HAUTOJ 1070: 小汽车的位置

    题目描述 有一辆智能小车,最初(时间为0)的位置为(0,0),我们想知道它最后的位置.小车以每小时10公里的速度向北移动(以北为y轴正向,以东为x轴正向).小车会受到一系列依照时间戳记排序的命令,1表 ...

  6. OJ1070: 小汽车的位置(C语言)

    题目描述 有一辆智能小车,最初(时间为0)的位置为(0,0),我们想知道它最后的位置.小车以每小时10公里的速度向北移动(以北为y轴正向,以东为x轴正向).小车会受到一系列依照时间戳记排序的命令,1表 ...

  7. 小汽车的位置(二维坐标运算)

    题目描述 有一辆智能小车,最初(时间为0)的位置为(0,0),我们想知道它最后的位置.小车以每小时10公里的速度向北移动(以北为y轴正向,以东为x轴正向).小车会受到一系列依照时间戳记排序的命令,1表 ...

  8. 1071: 小汽车的位置

    时间限制: 1 Sec  内存限制: 128 MB 题目描述 有一辆智能小车,最初(时间为0)的位置为(0,0),我们想知道它最后的位置.小车以每小时10公里的速度向北移动(以北为y轴正向,以东为x轴 ...

  9. 郑州轻工业大学OJ合集(C语言)【正在整理】

    代码仅供参考,为作者初次学习C语言时所写 以下代码均未添加注释 ZZULIOJ平台:http://acm.zzuli.edu.cn/ 学习编程语言,最忌眼高手低. copy后,不要直接粘到编译器里面, ...

最新文章

  1. final关键字最全了解
  2. 深度报告:一文看懂生物芯片产业
  3. python中abc属于字符串吗_Python基础学习:字符串
  4. java 常用十种设计模式示例归纳 | 已打包请带走
  5. 2.cocos2d-x坐标体系(UI坐标系,GL坐标系,本地坐标,世界坐标,节点坐标)
  6. linux修改权限后不能开机,打造完美Linux系统:疑难杂症的解决(转)
  7. 在 ASP.NET Core 中使用多种方式给 Action 传参
  8. C#+SQL Server数据库系统操作日志的实现完整案例
  9. Redhat7.3安装配置Telnet详细教程
  10. 新年快乐,送一台新款华为笔记本!
  11. 在两个ASP.NET页面之间传递变量【转】
  12. 通过anaconda安装jupyter lab
  13. 阶乘、斐波那契数列(java版)
  14. 计算理论101:这可能是讲FSM的最生动的一篇了
  15. 前馈神经网络开山鼻祖---一些概念
  16. CSDN页面完美格式打印
  17. 二进制逆向工程师_逆向工程工具集
  18. MotoSimEG-VRC软件:安川机器人摆动焊接虚拟仿真操作方法
  19. acer switch 10 linux,acer switch 10好不好
  20. 计算机网络信息管理制度,计算机网络及信息管理制度

热门文章

  1. 不可估量的善意:全球网友在Facebook捐了10亿美元善款
  2. 黔西南职称计算机,黔西南州人社局2016第七次贵州黔西南州职称计算机考试时间...
  3. c语言strlen注意事项
  4. 【STM32-V6】STM32F429BIT6开发板开源, 丰富软件资源, 强劲硬件配置, 配套400多实例, 9套手册持续更新中2019-08-04...
  5. 重构数据基础设施,打造金融“新基建”
  6. 2021--微信小程序流量主开通 (如何赚钱)
  7. P17-1.王道课后题-删除最小值元素
  8. OpenCV学习1 深复制 与 浅复制
  9. arcgis merge后打散工具
  10. 中国科学家发现侏罗纪时期带羽毛恐龙“飞行”新证据