gpt4 book ai didi

c# - 通过键盘按下输入文本的最短路径

转载 作者:塔克拉玛干 更新时间:2023-11-03 03:10:05 25 4
gpt4 key购买 nike

我从用户那里得到自定义字符串。现在我需要设计在包含 9 个按钮的键盘中按下此字符串的最短路线。

注意:

  • 解决方案字母应按字母顺序排列,即 a、b、c、d、e、...
  • 每个号码至少包含一个键盘字符

if input text = 'hello' 的解决方案

  1. a, b, c, d
  2. e, f, g
  3. h, i, j, k
  4. l, m, n
  5. o, p, q
  6. r, s, t
  7. 你,你,你
  8. x,y
  9. z

或者

  1. a, b, c, d
  2. e, f, g
  3. h, i, j, k
  4. l, m, n
  5. o
  6. p
  7. r
  8. s, t, u, v, w, x, y, z

使用这个键盘,我需要按 3、2、4、4、5 来输入“你好”

因此,如果您想使用这种设计的键盘输入“你好”,您只需按下键盘上的 5 个按钮,因为这是最少的键数。

我认为这道题是用贪心法或者回溯算法来解决的。

最佳答案

让我们将字母表概括为 {1, …, n}。令 k 为键的数量。对于 1 ≤ i < j ≤ k,可能的键 {i, …, j} 的成本(= 按下次数)是 1fi + 2fi+1 + … + (j - i + 1) fj,其中 fi 是字母 i 的频率。我们正在寻找恰好包含 k 个键的最小成本精确覆盖。

此问题具有以下最优子结构:修复任意最优解并删除带有 {m + 1, …, n} 的 key 。结果是具有 k - 1 个键和字母表 {1, …, m} 的问题的最优解;否则,我们可以通过重新排列前 k - 1 个键来改进第一个最优解。

据此,我们可以应用动态规划。对于每个 0 ≤ i ≤ n 和每个 0 ≤ j ≤ k,计算具有 j 个键的 {1, …, i} 的最优排列。这种安排的代价Ci,j满足递归

C0,j = 0 对于所有 j ≥ 0
Ci,0 = ∞ 对于所有 i > 0
Ci,j = min0 ≤ i' < i (Ci',j-1 + ci',j ),

其中 ca,b 是 key {a, …, b} 的成本。可以从最优参数序列 i' 中恢复排列本身。

关于c# - 通过键盘按下输入文本的最短路径,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8647698/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com