【LeetCode】每日一题 2024_11_21 矩阵中的蛇(模拟)

前言

每天和你一起刷 LeetCode 每日一题~

最近有些课程期中考试所以停更了几天,现在我又回来啦

本期看点:普通简单题

LeetCode 启动!

题目:矩阵中的蛇

代码与解题思路

题目让我从矩阵左上角的 0 元素开始,根据他给的命令数组进行移动,问移动之后的停在矩阵的哪个元素上

我最开始的想法是,直接把这个矩阵构造出来,然后遍历命令数组,记录走过的 x y 轴,然后通过下表的形式找到那个元素

但是转念一想,题目给出的矩阵是有规律的,也就意味着我们其实可以只遍历命令数组,根据规律解出最终的答案。问题来了,有什么规律?

核心思路:

往右走,元素大小会++,往下走,元素大小会 + n

最终代码如下:

go 复制代码
func finalPositionOfSnake(n int, commands []string) (ans int) {
    for _, v := range commands {
        if v[0] == 'U' {
            ans -= n
        }
        if v[0] == 'R' {
            ans++
        }
        if v[0] == 'D' {
            ans += n
        }
        if v[0] == 'L' {
            ans--
        }
    }
    return ans
}

每天进步一点点,我们明天不见不散~

可以和我刷一辈子的每日一题吗?

一题一题,积累起来就是一辈子。

相关推荐
乐分启航3 小时前
SliMamba:十余K参数量刷新SOTA!高光谱分类的“降维打击“来了
java·人工智能·深度学习·算法·机器学习·分类·数据挖掘
你真是饿了5 小时前
算法专题二:滑动窗口
算法
ccLianLian5 小时前
数论·约数
数据结构·算法
会编程的土豆5 小时前
【数据结构与算法】最短路径---Dijkstra 算法
数据结构·c++·算法
2401_879693875 小时前
C++中的观察者模式实战
开发语言·c++·算法
炽烈小老头5 小时前
【 每天学习一点算法 2026/03/24】寻找峰值
学习·算法
fff9811185 小时前
C++与Qt图形开发
开发语言·c++·算法
计算机安禾6 小时前
【数据结构与算法】第3篇:C语言核心机制回顾(二):动态内存管理与typedef
c语言·开发语言·数据结构·c++·算法·链表·visual studio
njidf6 小时前
C++中的访问者模式
开发语言·c++·算法
C_Si沉思6 小时前
C++中的工厂模式变体
开发语言·c++·算法