- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我即将完成 Udacity 的计算机科学入门 101 类(class),并正在寻求一些帮助来解决最终测验问题之一。以下代码在提交时返回“通过”,但我觉得我没有捕获本次测验中挑战的核心。任何有关如何处理和思考问题的帮助或建议将不胜感激。
问题:
"""
Define a Python procedure, in_language(<string>),
that takes as input a string and returns True
if the input string is in the language described by the BNF grammar below
(starting from S) and returns False otherwise.
BNF grammar description:
S => 0 S 1
S => 1 S 0
S => 0
"""
# Tests. These all should print True if your procedure is defined correctly
print in_language("00011") == True
print in_language("0") == True
print in_language("01") == False
print in_language("011") == False
print in_language("01002") == False
这是我到目前为止的代码:
def in_language(bnf):
if len(bnf) % 2 == 0:
return False
if any(i in '23456789' for i in bnf) == True:
return False
if bnf[len(bnf)/2] != '0':
return False
else:
return True
对于不给定巴科斯-诺尔表单的提交,此代码将返回 True:
S => 0 S 1
S => 1 S 0
S => 0
例如“11111011111”
print in_language('11111011111') == False
我仍然对递归很感兴趣,但似乎有一种方法可以递归地解决这个问题?或者我的下一步是检查字符串的第一个和最后一个字符,看看它们是否完全是零和一(不是两者),然后删除它们并继续修剪字符串,直到到达基本情况,或“中间”零。我很惊讶代码此时通过了测验。
值得注意的是,我对代码的思考:
if len(bnf) % 2 == 0:
我想到了第一个 if 条件,因为给定 B-N 形式,任何迭代都会产生奇数个数字,因此字符串长度能被 2 整除表示不属于这种形式。
if any(i in '23456789' for i in bnf) == True:
第二个“if”也是一个简单的考虑因素,因为问题只是寻找由 1 和 0 构成的字符串(我想我也可以包含字母表,或者简单地写成 if any(i not in '01' 代表 bnf 中的 i)
.
if bnf[len(bnf)/2] != '0':
第三个“if”类似地寻找给定 B-N 形式的限定特征 - 无论根据给定语法的表达式是什么,中间都会有一个零 - 并利用 Python 的底除法因为索引从零开始。
任何替代解决方案的想法或建议将不胜感激,谢谢!
由于我是 StackOverflow 的新手,我在发布之前研究了这个问题。任何发布风格的考虑(太冗长?)或担忧也会有帮助:)
<小时/>好的,
我采纳了 duskwoof 的建议并提出了这个:
def in_language(bnf):
# corresponding to: S => 0 S 1
if bnf[0] == '0' and bnf[-1] == '1':
return in_language(bnf[1:-1])
# corresponding to: S => 0 S 1
if bnf[0] == '1' and bnf[-1] == '0':
return in_language(bnf[1:-1])
# corresponding to: S => 0
if bnf == '0':
return True
return False
它适用于遵循该表单的案例,但是当我提交不遵循该表单的案例时,Python会感到厌烦……而且我仍然觉得我在递归和解析巴科斯-诺尔表单的字符串方面缺少一些东西。对于不符合表格的情况我应该如何考虑处理?感谢您的帮助。我会继续努力解决这个问题。
<小时/>这似乎效果更好 - 通过了所有测试用例:
def in_language(bnf):
if len(bnf) > 2:
# corresponding to: S => 0 S 1
if bnf[0] == '0' and bnf[-1] == '1':
return in_language(bnf[1:-1])
# corresponding to: S => 0 S 1
if bnf[0] == '1' and bnf[-1] == '0':
return in_language(bnf[1:-1])
# corresponding to: S => 0
if bnf == '0':
return True
return False
但是,我完全是一个新手@programming,所以任何建议或输入都会非常有帮助......我仍然不觉得我有一个非常通用的解决方案;只是这个特定 BNF 语法的特定内容。
最佳答案
I am still wrapping my head around recursion, but it seems like there is a way to address this problem recursively?
这正是您解决此问题的方式。不要试图通过分析该语言中的字符串将具有哪些属性(例如,长度模 2、它将包含哪些字符,等等)来过度思考问题!虽然这可能适用于这种特定语言,但它不适用于一般情况;有些语言太复杂,无法编写像您所描述的那样的迭代解决方案。
您的解决方案应该是语言描述的直接翻译 - 您不必过多考虑规则的含义! -- 并且应该对右侧有 S
的规则使用递归。应该写成这样的形式:
def in_language(bnf):
if ...: # corresponding to: S => 0 S 1
return True
if ...: # corresponding to: S => 1 S 0
return True
if ...: # corresponding to: S => 0
return True
return False
(您当前拥有的解决方案是“错误解决方案”——它将通过问题中给出的测试,但在某些其他输入上会失败。例如,字符串 000
不是用这种语言,但你的函数会说它是。)
关于python - newB 在 Udacity Computer 与 Backus Naur 斗争。科学。 101,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36212435/
我正在研究科学建模程序,但还没有让我的程序编译。我还没有触及我的教授坚持以前工作过的代码,只有 makefile。经过多次尝试,我得到的最远的是这个错误: Error on line 1112: De
有人知道对各种 Material 相互作用的行为进行编程的好资源吗? 游戏编程物理资源通常包括碰撞检测、动量、惯性等,但它们似乎处理一种理想化的“ Material ”。我感兴趣的是模拟弹丸撞击金属的
早上好 谁能帮我理解为什么在 Linux scientific 上打开 codeblock 并选择控制台后,在编译过程中它一直说找不到 g++ 并且不运行编译阶段?我们非常确定我们在初始化阶段插入了
我有一条由 (x,y) 对序列形成的轨迹。我想使用样条在此轨迹上插入点。 我该怎么做?使用 scipy.interpolate.UnivariateSpline 不起作用,因为 x 和 y 都不是单调
我正在从质谱仪读取数据文件,其中许多数字都是 e 格式的,例如 4096.26 5.785e1 4096.29 5.784e1 4096.31 5.784e1 4096.33 5.784e1 4096
我已经使用官方的Windows安装程序安装了Go(1.14),现在我正在阅读Go的书 https://www.golang-book.com/books/intro/1。它说: 对于Windows,安
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 8 年前。 Improve
我有一些方程式取决于许多变量。我想用 python 求解方程。这是一个更简单的方程式: f(x,y,theta,w) = x - y + theta * (w - y) 在给定其余参数的值的情况下,如
假设我有一个表达式,我需要找到它的总和: 边界是有限且已知的。在 scipy/numpy 中计算这样一个总和的最快或最有效的方法是什么。可以使用嵌套的 for 循环来完成,但是有更好的方法吗? 最佳答
因此根据 cplusplus.com,当您通过以下方式将输出流的格式标志设置为科学记数法时 of.setf(ios::scientific) 您应该在指数中看到 3 位加号和一个符号。但是,我的输出似
我在信号上使用 scipy.fft,使用移动窗口绘制随时间变化的频率幅度(这里是 an example,时间在 X 上,频率在 Y 上,并且振幅是颜色)。 但是,只有少数频率让我感兴趣(仅约 3、4
我使用的是来自Python的SciPy包,目的是解决一个有很多约束的最小化问题。。比方说我的解决方案有相互矛盾的限制。出于这个问题的目的,让我们假设我有这些限制:。有了这些界限[(0.001,无),(
我在 scipy 'leastsq' 优化例程中遇到问题,如果我执行下面的程序,它说 raise errors[info][1], errors[info][0] TypeError: Imp
假设我选择了一个随机来源,例如 CNN。根据关键字自动将抓取的文章分类,或者针对不同的类别抓取网站的各个部分,例如 cnn.com/tech 或/entertainment,这样会更有利吗?第二个选项
Python 的风格最佳实践是否适用于科学编码? 我发现很难保持科学 Python 代码的可读性。 例如,建议为变量使用有意义的名称,并通过避免 import * 来保持命名空间的顺序。因此,例如:
我想在 TIFF 文件中操作 RGB 波段并在 matplotlib 上输出 灰度 贴图。到目前为止我有这段代码,但我无法在灰度上得到它: import scipy as N import gdal
对于 Google 表格,我需要在一行中有 4 个复选框。他们代表(3)学校考试被拒。最后一个框是当所有这些都被拒绝时。 2 个月前,我对 VBA 一无所知,从那时起我就用 6 岁的代码制作了一系列宏
我即将完成 Udacity 的计算机科学入门 101 类(class),并正在寻求一些帮助来解决最终测验问题之一。以下代码在提交时返回“通过”,但我觉得我没有捕获本次测验中挑战的核心。任何有关如何处理
我是一名优秀的程序员,十分优秀!