代码日到来键盘难题

wufei123 2025-01-05 阅读:56 评论:0
第 21 天:键盘难题 github 存储库 - 解决方案 今天的挑战很难,我花了两天时间才解决,也完全理解了逻辑。今年我发现,我很难理解这些说明的意图。 我希望您像我一样从这个挑战和解决方案中学到了一些东西。我发现每年参加“ad...
第 21 天:键盘难题

github 存储库 - 解决方案

今天的挑战很难,我花了两天时间才解决,也完全理解了逻辑。今年我发现,我很难理解这些说明的意图。

我希望您像我一样从这个挑战和解决方案中学到了一些东西。我发现每年参加“advent of code”,我都会学到很多东西,这就是为什么我喜欢尝试不同的语言或推动自己走出舒适区。我认为 advent of code 更多的是一个学习/发展的机会,开发者应该分享他们的知识和想法,而不是仅仅将其视为一场竞赛。

今天对 python 的又一次尝试,我对这个解决方案很满意。我今天学到的东西是;在类声明上使用 @dataclass(frozen=true) 注释的不可变类。

我创建了 location 类作为辅助类来导航和更新坐标(有点像我之前在某些 c# 解决方案中使用 point 类所做的那样。

作为具有 c# / .net 强类型背景的人,我尝试在代码中添加类型,以帮助我可视化在这个复杂问题中我正在处理的内容。我在编写 typescript 时也习惯这样做,所以几乎是第二天性。

今天的问题

**第一部分**介绍了导航和控制多个机器人以将指令传递给下一个机器人以在数字键盘上输入代码的问题。

第二部分通过一系列机器人和方向键盘增加复杂性来解决这个问题,展示了多级依赖关系的指数性质。

演练

由于我们已经知道方向和键盘的布局,我们可以构建所有位置映射和他们可以移动的方向的字典。

缓存(cache 和 move_cache)

缓存:存储之前计算的最短序列,以避免冗余计算,提高性能。

moves_cache:存储键盘上任意两个按钮之间的所有有效移动序列,预先计算以便快速查找。

最短长度计算(shortest_length)

递归计算输入给定代码的最短按键顺序。

通过迭代级别 (cur_深度) 直至极限 (深度_限制) 来处理键盘的多级链接。

*在位置之间移动 (moves_ between_positions)
*

计算键盘上两个按钮之间的所有有效运动序列,确保机器人不会通过指向无效位置(间隙)来恐慌。

缓存初始化(create_cache_moves)

预先计算数字键盘和方向键盘上所有按钮对的有效移动序列,节省运行时计算。

求解函数,然后循环输入,通过将序列长度乘以代码的数字部分来计算其复杂性,然后根据谜题的要求简单地总结所有代码的复杂性。

排列

排列有什么作用?

python 中的排列函数(来自 itertools 模块)生成项目集合的所有可能的有序排列。

例如:

PHP
from itertools import permutations

items = ['a', 'b', 'c']
list(permutations(items))

这将产生:

PHP
[('a', 'b', 'c'), ('a', 'c', 'b'), ('b', 'a', 'c'), ('b', 'c', 'a'), ('c', 'a', 'b'), ('c', 'b', 'a')]

每个排列都是一个唯一的序列,包含原始集合中的所有项目,但顺序不同。

为什么使用排列而不是组合?

排列:

生成项目集合的所有可能的有序排列。
项目的顺序很重要。

然而,
组合:

生成项目集合的所有可能的无序选择。

项目的顺序并不重要。

为什么顺序在这种情况下很重要?

键盘导航:每次移动后,机器人在键盘上的位置都会发生变化,因此执行移动的顺序会直接影响结果。

有效移动检查: 该功能检查导航过程中中间位置的有效性。更改移动顺序可能会导致无效路径。

组合何时有用?

在移动顺序不重要或者您选择移动或按钮的子集而不关心其顺序的情况下,组合可能很有用。

当前使用排列是必要的,因为移动顺序对于键盘导航很重要。用组合替换它会破坏程序的逻辑。如果任务需要找到所有独特的动作或按键组(无论顺序如何),那么组合会更合适。

这个难题中最困难的部分是想出一种漂亮而干净的方法来跟踪机器人指令的深度(初始)级别——花了我一些时间,以便我可以全神贯注于它。

以上就是代码日到来键盘难题的详细内容,更多请关注知识资源分享宝库其它相关文章!

版权声明

本站内容来源于互联网搬运,
仅限用于小范围内传播学习,请在下载后24小时内删除,
如果有侵权内容、不妥之处,请第一时间联系我们删除。敬请谅解!
E-mail:dpw1001@163.com

分享:

扫一扫在手机阅读、分享本文

发表评论
热门文章
  • BioWare埃德蒙顿工作室面临关闭危机,龙腾世纪制作总监辞职引关注(龙腾.总监.辞职.危机.面临.....)

    BioWare埃德蒙顿工作室面临关闭危机,龙腾世纪制作总监辞职引关注(龙腾.总监.辞职.危机.面临.....)
    知名变性人制作总监corrine busche离职bioware,引发业界震荡!外媒“smash jt”独家报道称,《龙腾世纪:影幢守护者》制作总监corrine busche已离开bioware,此举不仅引发了关于个人职业发展方向的讨论,更因其可能预示着bioware埃德蒙顿工作室即将关闭而备受关注。本文将深入分析busche离职的原因及其对bioware及游戏行业的影响。 Busche的告别信:挑战与感激并存 据“Smash JT”获得的内部邮件显示,Busche离职原...
  • 闪耀暖暖靡城永恒怎么样-闪耀暖暖靡城永恒套装介绍(闪耀.暖暖.套装.介绍.....)

    闪耀暖暖靡城永恒怎么样-闪耀暖暖靡城永恒套装介绍(闪耀.暖暖.套装.介绍.....)
    闪耀暖暖钻石竞技场第十七赛季“华梦泡影”即将开启!全新闪耀性感套装【靡城永恒】震撼来袭!想知道如何获得这套精美套装吗?快来看看吧! 【靡城永恒】套装设计理念抢先看: 设计灵感源于夜色中的孤星,象征着淡然、漠视一切的灰色瞳眸。设计师希望通过这套服装,展现出在虚幻与真实交织的夜幕下,一种独特的魅力。 服装细节考究,从面料的光泽、鞋跟声响到裙摆的弧度,都力求完美还原设计初衷。 【靡城永恒】套装设计亮点: 闪耀的绸缎与金丝交织,轻盈的羽毛增添华贵感。 这套服装仿佛是从无尽的黑...
  • python怎么调用其他文件函数

    python怎么调用其他文件函数
    在 python 中调用其他文件中的函数,有两种方式:1. 使用 import 语句导入模块,然后调用 [模块名].[函数名]();2. 使用 from ... import 语句从模块导入特定函数,然后调用 [函数名]()。 如何在 Python 中调用其他文件中的函数 在 Python 中,您可以通过以下两种方式调用其他文件中的函数: 1. 使用 import 语句 优点:简单且易于使用。 缺点:会将整个模块导入到当前作用域中,可能会导致命名空间混乱。 步骤:...
  • 俄罗斯引擎yandex入口官网地址 yandex网址在线免费进入(俄罗斯.官网.在线免费.入口.地址......)

    俄罗斯引擎yandex入口官网地址 yandex网址在线免费进入(俄罗斯.官网.在线免费.入口.地址......)
    俄罗斯引擎yandex官网地址入口在哪里?这是不少网友都关注的问题,接下来由php小编为大家带来yandex网址在线免费进入,感兴趣的网友一起随小编来瞧瞧吧! 俄罗斯引擎yandex入口官网地址 1、俄罗斯引擎yandex入口官网地址☜☜☜☜☜点击进入 2、yandex网址在线免费进入☜☜☜☜☜点击进入 【俄罗斯引擎yandex】 1、Yandex的搜索引擎在俄罗斯拥有极高的市场份额,其算法针对俄语和斯拉夫语系进行了优化,能更好地理解用户意图,提供更精准的搜索结果。它不仅...
  • 斗魔骑士哪个角色强势-斗魔骑士角色推荐与实力解析(骑士.角色.强势.解析.实力.....)

    斗魔骑士哪个角色强势-斗魔骑士角色推荐与实力解析(骑士.角色.强势.解析.实力.....)
    斗魔骑士角色选择及战斗策略指南 斗魔骑士游戏中,众多角色各具特色,选择适合自己的角色才能在战斗中占据优势。本文将为您详细解读如何选择强力角色,并提供团队协作及角色培养策略。 如何选择强力角色? 斗魔骑士的角色大致分为近战和远程两种类型。近战角色通常拥有高攻击力和防御力,适合冲锋陷阵;远程角色则擅长后方输出,并依靠灵活走位躲避攻击。 选择角色时,需根据个人游戏风格和喜好决定。喜欢正面硬刚的玩家可以选择战士型角色,其高生命值和防御力能承受更多伤害;偏好策略性玩法的玩家则可以选择法...