- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在做 TAOCP 第 1 卷第 3 版的练习,但无法理解以下练习的答案中使用的语法。
第 1 章练习 8
通过指定 Tj,sj,aj,b 计算正整数 m 和 n 的最大公约数j
让您的输入由字符串 ambn 表示(m a 后跟 n b)
答案:
设 A = {a,b,c},N=5。该算法将以字符串 agcd(m,n)
终止j Tj sj bj aj 0 ab (empty) 1 2 Remove one a and one b, or go to 2. 1 (empty) c 0 0 Add c at extreme left, go back to 0. 2 a b 2 3 Change all a's to b's 3 c a 3 4 Change all c's to a's 4 b b 0 5 if b's remain, repeat
我无法理解的部分就是如何解释这个表。另外,当 Knuth 说这将以字符串 agcd(m,n) 终止时 - 为什么 gcd(m,n) 的上标?
感谢您的帮助!
编辑了更多问题:
什么是 Tj - 请注意 T = Theta
什么是 sj ——注意 s = phi
如何解释 bj 和 aj 列?
为什么 Knuth 将解决方案中的新符号转换为他在文本中没有解释的示例?只是令人沮丧。谢谢!!!
最佳答案
这是一个implementation该练习的答案。也许有帮助。
顺便说一句,该表似乎描述了一个 Markov algorithm .
据我所知,到目前为止,您从第一个命令集 j = 0 开始。将所有出现的 Tj 替换为 sj 并跳转到下一个命令行取决于您是否替换了任何内容(在这种情况下跳转到 bj,如果没有替换任何内容,则跳转到 aj)。
编辑:新答案:
A = {a,b,c} 似乎是您可以操作的字符集。 c 在算法过程中出现(添加到左侧,后来再次被 a 替换)。
Theta 和 phi 可能是您通常用于表示“原始”和“替换”之类的希腊字符,尽管我不知道它们是什么。
bj 和 aj 是接下来要执行的表行。这与最后一栏中人类可读的描述相匹配。
我唯一无法回答的是为什么 Knuth 在没有任何解释的情况下使用这个符号。我又浏览了一遍书中的前几章和解决方案,他没有提到任何地方。
EDIT2:gdc(2,2) = 2 的示例
Input string: aabb Line 0: Remove one a and one b, or go to 2. => ab => go to 1 Line 1: Add c at extreme left, go back to 0. => cab => go to 0 Line 0: Remove one a and one b, or go to 2. => c => go to 1 Line 1: Add c at extreme left, go back to 0. => cc => go to 0 Line 0: Remove one a and one b, or go to 2. No ab found, so go to 2 Line 2: Change all a's to b's No a's found, so go to 3 Line 3: Change all c's to a's => aa Line 4: if b's remain, repeat No b's found, so go to 5 (end). => Answer is "aa" => gdc(2,2) = 2
顺便说一句,我认为第 1 行的描述应该是“删除一个“ab”,或转到第 2 行。”这让事情变得更清楚了。
关于knuth - 计算机编程艺术练习题 : Chapter 1, 问题 8,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/575215/
无论是谁读到这篇文章,我都感谢您花时间阅读。 本质上,我试图通过调用 x 个方法来生成这个精确的 ASCII 艺术,我个人考虑了 3 个: * * ** ** ***
这太琐碎了,听起来很傻,但请多多包涵。 我以前会画ASCII艺术笑脸similar to this post通过做类似的事情: Console.Write((char)1); 当我在 Windows
这样的图像转换算法是如何工作的? 我想将位图转换为 ASCII 艺术。谁能帮我看看我应该使用哪种算法? . W ,
我正在尝试为 android 制作游戏。我目前已将所有美术资源加载到 drawables 文件夹中,但我的问题是如何实际引用特定资源来渲染它? 我知道每个文件都有一个唯一的@id,我可能必须在onDr
我试图垂直反射(reflect)这门艺术。 示例: 但这是我最终得到的: 代码如下: String reverse; for(int i=1;i=0;j--) // probably the wors
我正在尝试使用 JavaScript 函数在我的网站上获取一些 ASCII 艺术作品,但结果并不是我现在想要的...... 它应该是这样的: 这是我用来尝试实现该目标的代码: function log
我正在尝试创建一个脚本,该脚本将接受用户输入(仅字母)并向用户输出 ASCII 艺术。两种输出方法是水平或垂直。我遇到的问题是如何水平打印字典值。 这是我到目前为止所拥有的: def convert(
下面的代码(用 patorjk.com Text to ASCII Art Generator 生成)给出了预期的结果(“TEST”ASCII 艺术文本): Windows:Firefox、Chrom
我正在尝试像这样打印 ascii 艺术: print(("""\ ._ o o
所以..这是(无论如何对我来说)这个程序最重要的功能。我需要这个才能工作。请不要笑..(好吧你可以笑)但是当我的程序出错时,我希望它显示这个: _ _,---._ ,
我正在尝试输入 ASCII art在 C++ 程序中,并通过手动打印每一行来实现,但结果与 ASCII 艺术完全不同。就像: 出现这种情况是因为提示无法识别字符还是我没有正确操作? 这是我正在尝试做的
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
我有一个很长的多行 ascii 艺术字符串,我想使用 Python curses 模块将其呈现给用户。我对此有点困惑,因为在 curses 中打印字符串的唯一方法是 addstr(y,x,string
目前我正在尝试读取可能包含 ASCII 艺术的 .txt 文件并使用 JQuery 在我的 HTML 文档中显示它们。简单的文本显示正确,但我有艺术格式问题。 我该如何解决这个问题? $(docume
我正在用 optparse 模块制作一个 shell 脚本,只是为了好玩,所以我想打印一个漂亮的 ascii 图来代替描述。 原来这段代码: parser = optparse.OptionParse
我是 python 的新手,把它作为一种兴趣爱好,通过一些搜索,我自己找到了一堆来自“计算实践”的练习,其中一个是关于写作的一个 ASCII 数字,如下所示。 这似乎是一个足够简单的练习,但我似乎无法
这个问题在这里已经有了答案: Render a string in HTML and preserve spaces and linebreaks (7 个答案) 关闭 9 个月前。 我该怎么做才能
我曾经为一项工作做过编程测试,其中涉及用 C# 制作 ASCii 艺术。我在这方面做得并不好,因为我对在 C#(或任何编程知识)中这样做的想法或经验知之甚少。 .NET 中是否有任何值得了解/练习的资
我正在编写一个小程序,想知道是否有办法在 R 中包含 ASCII 艺术。我在 python 中寻找等效的三个引号( """ 或 ''' )。 我尝试使用 cat或 print没有成功。 最佳答案 不幸
因此,对于我的 Java 入门类(class),我想用 ASCII 创建一个 Gingerbread 人。这是第一个作业,所以到目前为止,该类(class)仅涵盖了 println 语句。我在 OSX
我是一名优秀的程序员,十分优秀!