计蒜客T1666 顺丰快递 (C语言实现)

【题目描述】顺丰快递的原理就是利用每个时刻的风向来运送货物,这样可以做到节能减排。现在已知起点和终点的坐标,以及接下来n个时刻的风向(东南西北),每次可以选择顺风偏移1各单位或者停在原地。求到达终点的最少时间。

【输入格式】第一行两个正整数x1,y1,表示小明所在位置。第二行两个正整数x2,y2,表示小明想去的位置。第三行一个整数n,表示n个时刻。第四行第第n+3行,每行一个字符,表示风向,即东南西北的英文单词的首字母。东:East,南:South,西:West,北:North。

【输出格式】一个整数,最少走多少步,如果无法偏移至终点,输出-1。

【C语言实现】

c 复制代码
# include <stdio.h>
int main()
{
    int x1, y1, x2, y2, n;
    scanf("%d%d%d%d%d", &x1, &y1, &x2, &y2, &n); // 按题意要求输入
    getchar(); // 读走换行符
    int dig = 0; // 变量dig记录走了多少步
    for (int i = 0; i < n; ++i) { // n个时刻循环
        char ch;
        ch = getchar(); // 读入风向
        if (x1 > x2 && ch == 'W') { // 西风,终点位置的横坐标在当前位置的左侧
            ++dig; // 步数加1
            --x1; // 向左移动x1
        } else if (x1 < x2 && ch == 'E') { // 东风,终点位置的横坐标在当前位置的右侧
            ++dig; // 步数加1
            ++x1; // 向右移动x1
        } else if (y1 < y2 && ch == 'N') { // 北风,终点位置的纵坐标在当前位置的上方
            ++dig; // 步数加1
            ++y1; // 向上移动y1
        } else if (y1 > y2 && ch == 'S') { // 南风,终点位置的纵坐标在当前位置的下方
            ++dig; // 步数加1
            --y1; // 向下移动y1
        }
        getchar(); // 读走换行符
    }
    if (x1 == x2 && y1 == y2) { // 到达终点位置,输出步数
        printf("%d", dig);
    } else { // 未到终点位置,输出-1
        printf("-1");
    }
    return 0;
}
相关推荐
Zsy_0510036 分钟前
【数据结构】二叉树介绍及C语言代码实现
c语言·数据结构·算法
脏脏a1 小时前
【初阶数据结构】栈与队列:定义、核心操作与代码解析
c语言·开发语言
C语言不精1 小时前
一种在 ESP32-S3 上取巧的清晰度检测方案
c语言·stm32·嵌入式硬件·学习
Bigan(安)2 小时前
【奶茶Beta专项】【LVGL9.4源码分析】03-显示框架-图层管理
linux·c语言·mcu·arm·unix
云雾J视界2 小时前
51单片机信号处理实战:C语言A/D与D/A转换应用,从传感器采集到PWM控制全解析
c语言·51单片机·信号处理·pwm·模拟信号·数字信号·a/d
WongKyunban2 小时前
使用Valgrind检测内存问题(C语言)
c语言·开发语言
代码游侠2 小时前
数据结构——线性表
linux·c语言·数据结构·学习·算法
橘子编程2 小时前
仓颉语言:华为新一代编程利器
java·c语言·开发语言·数据库·python·青少年编程
lingggggaaaa2 小时前
免杀对抗——C2远控篇&PowerShell&C#&对抗AV-EDR&停用AMSI接口&阻断ETW跟踪&调用
c语言·开发语言·c++·学习·安全·c#·免杀对抗
繁星星繁2 小时前
CMake快速上手
c语言·c++·编辑器·学习方法·visual studio code