javascript - CoffeeScript/JavaScript : why assign a letter to a variable that has a number assigned?

标签 javascript coffeescript

我是一个没有经验的 JavaScript 用户,正在阅读这本书 CoffeeScript: Accelerated JavaScript Development ,其中作者制作了一种 Scrabble 应用程序(在 5 x 5 网格中使用 Scrabble 单词)来在实践中演示一些概念。我在使用下面的 randomLetter 方法时遇到了一些问题。有人可以引用以下几点解释下面的代码片段:

i) 作者执行了 x = 1,但随后似乎用 x +=tileCounts[letter] 为 x 分配了一个字母。为什么要这么做?

ii)如果与我在(i)中的假设相反,他为 x 分配了一个数字而不是一个字母,那么“字母”实际上代表与每个字母相关的数字是如何工作的?

iii) 根据你在这里看到的内容,你能弄清楚为什么他只在 x 大于 randomNumber 时才返回 x 吗?我意识到这里可能没有足够的信息来回答这个问题,但如果有,请解释一下

tileCounts =
  A: 9, B: 2, C: 2, D: 4, E: 12, F: 2, G: 3, H: 2, I: 9, J: 1, K: 1, L: 4
  M: 2, N: 6, O: 8, P: 2, Q: 1, R: 6, S: 4, T: 6, U: 4, V: 2, W: 2, X: 1
  Y: 2, Z: 1

totalTiles = 0
totalTiles += count for letter, count of tileCounts
alphabet = (letter for letter of tileCounts).sort()

randomLetter = ->  
  randomNumber = Math.ceil Math.random() * totalTiles
  x = 1
  for letter in alphabet
    x += tileCounts[letter]
    return letter if x > randomNumber
#END:moduleVars

最佳答案

我同意randomLetter()很难理解。作为这本书的作者,让我尝试澄清一下。

纯 JavaScript 中唯一可用的随机形式是 Math.random(),它返回 0 到 1 之间的数字。所以 randomLetter() 的想法> 是将随机数转换为随机字母,每个字母被抽取的概率与包含该字母的拼字游戏图 block 的数量成正比。

为了使我们模拟的类比更加精确,请想象一叠从 "A""Z" 排序的所有拼字游戏图 block 。那么我们所要做的就是:

  1. Math.random() 的输出(范围为 01)转换为范围为 0 的内容code> 到 totalTiles(图 block 堆栈的大小)并将其分配给 randomNumber
  2. 遍历堆栈,直到到达第 randomNumber 个图 block 并返回该字母。

事后看来,我可能应该编写这个函数,以便更字面地遵循该类比,首先创建所有图 block 的数组,然后从中抽取随机值。相反,我选择了一种间接方法:遍历字母表中的字母,绘制带有该字母的所有图 block ,并询问“我们已经绘制了 randomNumber 图 block 了吗?如果是这样,我们就已经达到了我们的目标。”随机字母。”

因此,给出一个简短的答案:x 表示从堆栈中绘制的图 block 数量,首先绘制所有 “A” s,然后是“B”,依此类推。

希望对您有所帮助!

关于javascript - CoffeeScript/JavaScript : why assign a letter to a variable that has a number assigned?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10568942/

相关文章:

Javascript - 在视频直播结束前隐藏 div 1 秒

javascript - 如何在 CoffeeScript 中导入 javascript 库?

python - 在生产环境中使用 Flask 编译 Coffeescript

javascript - 引用错误 : CoffeeScript + JsTestDriver + Qunit

javascript - 主干模型和普通对象

javascript - 为什么这个 jquery 函数没有被调用

javascript - 欧芹错误消息类覆盖

javascript - 带有元素标题的 HTML 链接。它是如何工作的?

javascript - Backbone.Collection.reset() 在 IE8 中抛出异常

javascript - 有没有更有效的方法来过滤这个对象数组?