- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在做《Code Wars》中的这个问题。我已经完成了基本的摩尔斯电码功能,但我没有找到解决其他一些测试用例的方法。
测试的代码对于 8/12 测试用例是正确的。我如何测试较长的句子,例如“The Brown Quick Fox Jumped over the起始狗”、“E E”的测试用例和“S O S”的测试用例?
这是我的代码:
def decodeMorse(morse_code):
space_pos = morse_code.find(" ")
match_str = ''.join(MORSE_CODE.get(i) for i in morse_code.split())
match_list = list(match_str)
if space_pos >= 0:
edit_match = match_list.insert(int(space_pos/3.5), " ")
final_str = ''.join(match_list)
return final_str
这是Code Wars Kata我正在看:
In this kata you have to write a simple Morse code decoder. While the Morse code is now mostly superseded by voice and digital data communication channels, it still has its use in some applications around the world.
The Morse code encodes every character as a sequence of "dots" and "dashes". For example, the letter
A
is coded as·−
, letterQ
is coded as−−·−
, and digit1
is coded as·−−−−
. The Morse code is case-insensitive, traditionally capital letters are used. When the message is written in Morse code, a single space is used to separate the character codes and 3 spaces are used to separate words. For example, the messageHEY JUDE
in Morse code is···· · −·−− ·−−− ··− −·· ·
.NOTE: Extra spaces before or after the code have no meaning and should be ignored.
In addition to letters, digits and some punctuation, there are some special service codes, the most notorious of those is the international distress signal SOS (that was first issued by Titanic), that is coded as
···−−−···
. These special codes are treated as single special characters, and usually are transmitted as separate words.Your task is to implement a function that would take the morse code as input and return a decoded human-readable string.
For example:
decodeMorse('.... . -.-- .--- ..- -.. .')
#should return "HEY JUDE"NOTE: For coding purposes you have to use ASCII characters
.
and-
, not Unicode characters.The Morse code table is preloaded for you as a dictionary, feel free to use it:
MORSE_CODE['.--']
最佳答案
问题是,使用 morse_code.find("")
您只能找到第一个双空格的索引。无法保证您的输入仅包含两个单词。您还需要检测输入字符串中的任何其他双空格。
其次,将此位置除以 3.5 无法可靠地知道在最终翻译的字符串中插入空格的位置。尽管这可能是莫尔斯编码中字母宽度的良好平均值,但有些单词的宽度更接近每个字母 2 个。
您应该通过执行 .split("")
将输入拆分为单词。然后分别解决每个单词的问题,最后将这些单独的翻译连接在一起,中间有一个空格。
如果将问题分解为以下步骤,那就非常简单了:
这是一个可能的 Python 解决方案:
# helper function to solve the problem for just one Morse-word
def decodeMorseWord(morse_word):
return "".join([MORSE_CODE[morse_letter] for morse_letter in morse_word.split(' ')])
def decodeMorse(morse_code):
return " ".join([decodeMorseWord(morse_word) for morse_word in morse_code.split(' ')])
关于python - 莫尔斯电码程序不处理带空格的测试用例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59179747/
运行 PostgreSQL(7.4 和 8.x),我认为这是可行的,但现在我遇到了错误。 我可以单独运行查询,它工作得很好,但如果我使用 UNION 或 UNION ALL,它会抛出错误。 这个错误:
我试图为我的应用程序创建一个导航,使用抽屉导航我的 fragment 之一(HomeFragment)有一个 ViewPager,可容纳 3 个 fragment (Bundy Clock、Annou
以我目前正在开发的应用为例: - 它有一个包含多个项目的抽屉导航;现在有两个项目让我感兴趣,我将它们称为 X 和 Y。 X 和 Y 都在单击时显示包含 x 元素或 y 元素列表的 fragment 选
我有一个形状为 (370,275,210) 的 NumPy 数组,我想将其重新整形为 (275,210,370)。我将如何在 Python 中实现这一点? 370是波段数,275是行数,210是图像包
我们如何与被子 UIViewController 阻止的父 UIViewController(具有按钮)交互。显然,触摸事件不会通过子 Nib 。 (启用用户交互) 注意:我正在加载默认和自定义 NI
我是 Jpa 新手,我想执行过程 我的代码如下 private static final String PERSISTENCE_UNIT_NAME = "todos"; private static
与安装了 LAMP 的 GCE 相比,选择与 Google Cloud SQL 链接的 GCE 实例有哪些优势? 我确定 GCE 是可扩展的,但是安装在其上的 mysql 数据库的可扩展性如何? 使用
这个问题在这里已经有了答案: Value receiver vs. pointer receiver (3 个答案) 关闭 3 年前。 我刚接触 golang。只是想了解为 Calc 类型声明的两种
我不小心按了一个快捷键,一个非常漂亮的断线出现在日期上。 有点像 # 23 Jun 2010 -------------------- 有人知道有问题的快捷方式吗?? (我在 mac 上工作!) 在
我正在Scala中编写正则表达式 val regex = "^foo.*$".r 这很好,但是如果我想做 var x = "foo" val regex = s"""^$x.*$""".r 现在我们有
以下 XML 文档在技术上是否相同? James Dean 19 和: James Dean 19 最佳答案 这两个文档在语义上是相同的。在 X
我在对数据帧列表运行稳健的线性回归模型(使用 MASS 库中的 rlm)时遇到问题。 可重现的示例: var1 <- c(1:100) var2 <- var1*var1 df1 <- data.f
好的,我有一个自定义数字键盘,可以在标签(numberField)中将数字显示为 0.00,现在我需要它显示 $0.00。 NSString *digit = sender.currentTitle;
在基于文档的应用程序中,使用 XIB 文件,创建新窗口时其行为是: 根据最后一个事件的位置进行定位和调整大小 window 。 如果最后一个事件窗口仍然可见,则新窗口 窗口应该是级联的,这样它就不会直
我想使用参数进行查询,如下所示: SELECT * FROM MATABLE WHERE MT_ID IN (368134, 181956) 所以我考虑一下 SELECT * FROM MATABLE
我遇到一些性能问题。 我有一个大约有 200 万行的表。 CREATE TABLE [dbo].[M8]( [M8_ID] [int] IDENTITY(1,1) NOT NULL,
我在 jquery 中的按键功能遇到问题。我不知道为什么按键功能不起作用。我已经使用了正确的 key 代码。在我的函数中有 2 个代码,其中包含 2 个事件键,按一个键表示 (+) 代码 107 和(
我想显示音频波形,我得到了此代码,它需要.raw音频输入并显示音频波形,但是当我放入.3gp,.mp3音频时,我得到白噪声,有人可以帮助我如何使其按需与.3gp一起使用使用.3gp音频运行它。 Inp
我无法让 stristr 函数返回真值,我相信这是因为我的搜索中有一个 $ 字符。 当我这样做时: var_dump($nopricecart); 完整的 $nopricecart 值是 $0 ,我得
如果我有这样的循环: for(int i=0;i O(n) 次。所以do some执行了O(n)次。如果做某事是线性时间,那么代码片段的复杂度是O(n^2)。 关于algorithm - 带 If 语
我是一名优秀的程序员,十分优秀!