”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 。眼睛键盘

。眼睛键盘

发布于2024-08-20
浏览:723

. eys Keyboard

650。 2键键盘

难度: 中等

主题: 数学、动态规划

记事本的屏幕上只有一个字符“A”。您可以在此记事本上为每个步骤执行以下两个操作之一:

  • 全部复制:您可以复制屏幕上出现的所有字符(不允许部分复制)。
  • 粘贴:可以粘贴上次复制的字符。

给定一个整数n,返回在屏幕上准确地出现n次字符“A”的最少操作次数

示例1:

  • 输入: n = 3
  • 输出: 3
  • 解释: 最初,我们有一个字符“A”。
    • 在步骤1中,我们使用全部复制操作。
    • 在步骤2中,我们使用粘贴操作得到'AA'。
    • 在第3步中,我们使用粘贴操作来获取'AAA'。

示例2:

  • 输入: n = 1
  • 输出: 0

示例3:

  • 输入: n = 10
  • 输出: 7

示例2:

  • 输入: n = 24
  • 输出: 9

约束:

  • 1

暗示:

  1. 如果n = 3,最后一步剪贴板中可能有多少个字符? n = 7? n = 10? n = 24?

解决方案:

我们需要找到最少的操作次数才能在屏幕上精确地显示 n 个字符“A”。我们将使用动态编程方法来实现这一目标。

  1. 理解问题:

    • 我们从屏幕上的一个“A”开始。
    • 我们可以“全部复制”(复制当前屏幕内容)或“粘贴”(粘贴最后复制的内容)。
    • 我们需要确定屏幕上恰好有 n 个字符“A”所需的最少操作。
  2. 动态规划方法:

    • 使用动态编程 (DP) 数组 dp,其中 dp[i] 表示在屏幕上精确获取 i 个字符所需的最少操作数。
    • 初始化 dp[1] = 0,因为需要 0 次操作才能在屏幕上显示一个“A”。
    • 对于从 2 到 n 的每个字符 i,通过检查 i 的每个除数来计算最少运算。如果 i 能被 d 整除,则:
      • 达到 i 所需的运算次数是达到 d 的运算加上 d 相乘得到 i 所需的运算之和。
  3. 解决步骤:

    • 使用 INF(或一个大数字)初始化 DP 数组,以获取除 dp[1] 之外的所有值。
    • 对于从 2 到 n 的每个 i,迭代 i 的可能除数,并根据通过复制和粘贴达到 i 所需的操作更新 dp[i]。

让我们用 PHP 实现这个解决方案:650。 2键键盘


解释:

  • 初始化: dp 被初始化为一个很大的数字(PHP_INT_MAX),以表示最初不可达的状态。
  • 除数检查: 对于每个数字 i,检查所有除数 d。通过考虑到达 d 所需的操作然后相乘得到 i 来更新 dp[i]。
  • 输出: 结果是 dp[n] 的值,它给出了在屏幕上精确获取 n 个字符所需的最少操作。

这种方法确保我们针对给定的约束有效地计算最少的操作。

联系链接

如果您发现本系列有帮助,请考虑在 GitHub 上给存储库 一颗星,或者在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

如果您想要更多类似的有用内容,请随时关注我:

  • 领英
  • GitHub
版本声明 本文转载于:https://dev.to/mdarifulhaque/650-2-keys-keyboard-57n0?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    在javascript console 中显示颜色是可以使用chrome的控制台显示彩色文本,例如红色的redors,for for for for错误消息?回答是的,可以使用CSS将颜色添加到Chrome和Firefox中的控制台显示的消息(版本31或更高版本)中。要实现这一目标,请使用以下模...
    编程 发布于2025-07-15
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-07-15
  • 在C#中如何高效重复字符串字符用于缩进?
    在C#中如何高效重复字符串字符用于缩进?
    在基于项目的深度下固定字符串时,重复一个字符串以进行凹痕,很方便有效地有一种有效的方法来返回字符串重复指定的次数的字符串。使用指定的次数。 constructor 这将返回字符串“ -----”。 字符串凹痕= new String(' - ',depth); console.Wr...
    编程 发布于2025-07-15
  • 为什么PHP的DateTime :: Modify('+1个月')会产生意外的结果?
    为什么PHP的DateTime :: Modify('+1个月')会产生意外的结果?
    使用php dateTime修改月份:发现预期的行为在使用PHP的DateTime类时,添加或减去几个月可能并不总是会产生预期的结果。正如文档所警告的那样,“当心”这些操作的“不像看起来那样直观。 考虑文档中给出的示例:这是内部发生的事情: 现在在3月3日添加另一个月,因为2月在2001年只有2...
    编程 发布于2025-07-15
  • Java是否允许多种返回类型:仔细研究通用方法?
    Java是否允许多种返回类型:仔细研究通用方法?
    在Java中的多个返回类型:一种误解类型:在Java编程中揭示,在Java编程中,Peculiar方法签名可能会出现,可能会出现,使开发人员陷入困境,使开发人员陷入困境。 getResult(string s); ,其中foo是自定义类。该方法声明似乎拥有两种返回类型:列表和E。但这确实是如此吗...
    编程 发布于2025-07-15
  • Java中Lambda表达式为何需要“final”或“有效final”变量?
    Java中Lambda表达式为何需要“final”或“有效final”变量?
    Lambda Expressions Require "Final" or "Effectively Final" VariablesThe error message "Variable used in lambda expression shou...
    编程 发布于2025-07-15
  • HTML格式标签
    HTML格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-07-15
  • 如何同步迭代并从PHP中的两个等级阵列打印值?
    如何同步迭代并从PHP中的两个等级阵列打印值?
    同步的迭代和打印值来自相同大小的两个数组使用两个数组相等大小的selectbox时,一个包含country代码的数组,另一个包含乡村代码,另一个包含其相应名称的数组,可能会因不当提供了exply for for for the uncore for the forsion for for ytry...
    编程 发布于2025-07-15
  • 如何使用Depimal.parse()中的指数表示法中的数字?
    如何使用Depimal.parse()中的指数表示法中的数字?
    在尝试使用Decimal.parse(“ 1.2345e-02”中的指数符号表示法表示的字符串时,您可能会遇到错误。这是因为默认解析方法无法识别指数符号。 成功解析这样的字符串,您需要明确指定它代表浮点数。您可以使用numbersTyles.Float样式进行此操作,如下所示:[&& && && ...
    编程 发布于2025-07-15
  • 如何简化PHP中的JSON解析以获取多维阵列?
    如何简化PHP中的JSON解析以获取多维阵列?
    php 试图在PHP中解析JSON数据的JSON可能具有挑战性,尤其是在处理多维数组时。 To simplify the process, it's recommended to parse the JSON as an array rather than an object.To do...
    编程 发布于2025-07-15
  • PHP阵列键值异常:了解07和08的好奇情况
    PHP阵列键值异常:了解07和08的好奇情况
    PHP数组键值问题,使用07&08 在给定数月的数组中,键值07和08呈现令人困惑的行为时,就会出现一个不寻常的问题。运行print_r($月)返回意外结果:键“ 07”丢失,而键“ 08”分配给了9月的值。此问题源于PHP对领先零的解释。当一个数字带有0(例如07或08)的前缀时,PHP将其...
    编程 发布于2025-07-15
  • 解决MySQL插入Emoji时出现的\\"字符串值错误\\"异常
    解决MySQL插入Emoji时出现的\\"字符串值错误\\"异常
    Resolving Incorrect String Value Exception When Inserting EmojiWhen attempting to insert a string containing emoji characters into a MySQL database us...
    编程 发布于2025-07-15
  • 对象拟合:IE和Edge中的封面失败,如何修复?
    对象拟合:IE和Edge中的封面失败,如何修复?
    To resolve this issue, we employ a clever CSS solution that solves the problem:position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%)...
    编程 发布于2025-07-15
  • 如何使用Python的请求和假用户代理绕过网站块?
    如何使用Python的请求和假用户代理绕过网站块?
    如何使用Python的请求模拟浏览器行为,以及伪造的用户代理提供了一个用户 - 代理标头一个有效方法是提供有效的用户式header,以提供有效的用户 - 设置,该标题可以通过browser和Acterner Systems the equestersystermery和操作系统。通过模仿像Chro...
    编程 发布于2025-07-15
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-07-15

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3