搜索

火柴棍压缩

Nov 25, 2024 pm 03:56 PM

Matchstick compression

每周挑战 296

穆罕默德·S·安瓦尔 (Mohammad S. Anwar) 每周都会发出“每周挑战”,让我们所有人都有机会为每周两次的任务提出解决方案。我的解决方案首先用Python编写,然后转换为Perl。这对我们所有人来说都是练习编码的好方法。

挑战,我的解决方案

任务 1:字符串压缩

任务

您将获得一串字母字符,$chars。

编写一个脚本,使用游程编码来压缩字符串,如示例所示。

压缩单元可以是单个字符,也可以是计数后跟一个字符。

奖励:编写一个解压缩函数。

我的解决方案

由于正则表达式的强大功能,这是一项非常简单的任务。 Python 和 Perl 都允许替换值是一个函数。因此,我有一个名为 sc 的函数,它将多个字母转换为数字和字母。例如如果输入是aaa,它将返回3a。

def sc(match):
    m = match.group(0)
    return str(len(m)) + m[0]

然后就是根据需要调用这个函数了。

def string_compress(s: str) -> str:
    return re.sub(r'(([a-z])+)', sc, s)

解压缩函数(仅限Python)以类似的方式工作。它采用数字后跟字母的模式,并将其更改为重复指定次数的字母。

def usc(match):
    m = match.group(0)
    return m[-1] * int (m[:-1])

def string_decompress(s: str) -> str:
    return re.sub(r'(\d+[a-z])', usc, s)

为了从命令行执行,我使用 argparse 模块来查看是否指定了 --decompress 选项。

def main():
    parser = argparse.ArgumentParser()
    parser.add_argument("--decompress", help="decompress the input", action='store_true')
    parser.add_argument("str", help="the string to compress/decompress")
    args = parser.parse_args()

    if args.decompress:
        result = string_decompress(args.str)
    else:
        result = string_compress(args.str)
    print(result)

示例

$ ./ch-1.py abbc
a2bc

$ ./ch-1.py aaabccc
3ab3c

$ ./ch-1.py abcc
ab2c

$ ./ch-1.py --decompress a2bc
abbc

$ ./ch-1.py --decompress 3ab3c
aaabccc

$ ./ch-1.py --decompress ab2c
abcc

任务2:火柴方

任务

给你一个整数数组,@ints。

编写一个脚本来查找是否可以使用给定数组 @ints 中的棍子制作一个正方形,其中 $ints[ì] 是第 i 根棍子的长度。

我的解决方案

这会有点长,所以请系好安全带。我检查的第一件事是木棍的总和是否能被四整除。如果不是,没有可能的解决方案,我可以返回 false

我还可以检查没有一根棍子比一侧长。如果发生这种情况,我也会返回 false。

通过这两项检查,所有示例都会给出正确的结果。然而,它会错误地报告 4 3 3 3 3 为真,而实际上并非如此。

尝试二

查看示例和我自己的想法,我认为解决方案是匹配一对值来匹配每一侧。因此,对于示例 3 4 1 4 3 1,我们有两对 3 和 1 棍子,组成四根棍子。这将解决 4 3 3 3 3 问题,因为 3 没有匹配的。

但是如果棍子是 4 4 3 1 2 1 1,这将不起作用,因为一侧使用三根棍子(一根 2 和两根 1)

尝试三

所以我的下一次尝试有点复杂,我认为这是一个很好的解决方案......直到它不是。对于这次尝试,我从最长的棍子开始。如果不是边的长度,我就拿完成边所需的下一根最长的棍子,然后重复,直到没有可能的解决方案。使用此方法,以下解决方案是正确的。

  • 4 4 3 1 2 1 1
  • 9 5 4 3 3 3 3 3 3
  • 9 6 3 5 4 3 3 3
  • 9 6 3 5 4 3 3 2 1

我以为这就是解决方案,直到我意识到 9 5 3 1 5 2 2 3 3 3 不起作用。第一条边是 9,下一条边是 5 3 1,第三条边会失败,只有 5 3 而没有 1。

尝试四

此时,我开始怀疑是否有可能想出一个不涉及暴力的解决方案。所以我睡在上面,在平板电脑上写下了很多东西(我正在度假,所以不能使用我的白板),然后又睡在上面。我的结论是使用递归函数是唯一的解决方案。

也许我只是想太多了,或者也许有一个我刚刚想到的真正简单的解决方案(就像上周的情况)。

最终代码

还在读书吗?干得好:)

对于这个任务,我有一个名为 make_side 的递归函数。它需要一个剩余棍棒的列表(Perl 中的 arrayref)以及所需的长度。然后它会遍历剩余的棍子(首先是最高的)。然后发生以下三件事之一:

  • 如果棍子比要求的长度长,我会跳过它。
  • 如果是需要的长度,我就返回。
  • 如果它很短,我会使用它并再次调用该函数以使用另一根棍子。该调用会删除已使用的棍子,并根据已使用的棍子的长度减少所需的长度。

该函数将返回所使用的棍子列表,如果未找到有效的棍子组合,则返回 None(Perl 中的 undef)。

def sc(match):
    m = match.group(0)
    return str(len(m)) + m[0]

拼图的最后一块,我执行第一部分中提到的检查(总和可以被四整除,长度不能超过边长),然后调用上面的函数。如果返回 None,我返回 false。如果所有的棍子都被使用,我返回true。

def string_compress(s: str) -> str:
    return re.sub(r'(([a-z])+)', sc, s)

示例

def usc(match):
    m = match.group(0)
    return m[-1] * int (m[:-1])

def string_decompress(s: str) -> str:
    return re.sub(r'(\d+[a-z])', usc, s)

以上是火柴棍压缩的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python中的合并列表:选择正确的方法Python中的合并列表:选择正确的方法May 14, 2025 am 12:11 AM

Tomergelistsinpython,YouCanusethe操作员,estextMethod,ListComprehension,Oritertools

如何在Python 3中加入两个列表?如何在Python 3中加入两个列表?May 14, 2025 am 12:09 AM

在Python3中,可以通过多种方法连接两个列表:1)使用 运算符,适用于小列表,但对大列表效率低;2)使用extend方法,适用于大列表,内存效率高,但会修改原列表;3)使用*运算符,适用于合并多个列表,不修改原列表;4)使用itertools.chain,适用于大数据集,内存效率高。

Python串联列表字符串Python串联列表字符串May 14, 2025 am 12:08 AM

使用join()方法是Python中从列表连接字符串最有效的方法。1)使用join()方法高效且易读。2)循环使用 运算符对大列表效率低。3)列表推导式与join()结合适用于需要转换的场景。4)reduce()方法适用于其他类型归约,但对字符串连接效率低。完整句子结束。

Python执行,那是什么?Python执行,那是什么?May 14, 2025 am 12:06 AM

pythonexecutionistheprocessoftransformingpypythoncodeintoExecutablestructions.1)InternterPreterReadSthecode,ConvertingTingitIntObyTecode,whepythonvirtualmachine(pvm)theglobalinterpreterpreterpreterpreterlock(gil)the thepythonvirtualmachine(pvm)

Python:关键功能是什么Python:关键功能是什么May 14, 2025 am 12:02 AM

Python的关键特性包括:1.语法简洁易懂,适合初学者;2.动态类型系统,提高开发速度;3.丰富的标准库,支持多种任务;4.强大的社区和生态系统,提供广泛支持;5.解释性,适合脚本和快速原型开发;6.多范式支持,适用于各种编程风格。

Python:编译器还是解释器?Python:编译器还是解释器?May 13, 2025 am 12:10 AM

Python是解释型语言,但也包含编译过程。1)Python代码先编译成字节码。2)字节码由Python虚拟机解释执行。3)这种混合机制使Python既灵活又高效,但执行速度不如完全编译型语言。

python用于循环与循环时:何时使用哪个?python用于循环与循环时:何时使用哪个?May 13, 2025 am 12:07 AM

useeAforloopWheniteratingOveraseQuenceOrforAspecificnumberoftimes; useAwhiLeLoopWhenconTinuingUntilAcIntiment.ForloopSareIdeAlforkNownsences,而WhileLeleLeleLeleLoopSituationSituationSituationsItuationSuationSituationswithUndEtermentersitations。

Python循环:最常见的错误Python循环:最常见的错误May 13, 2025 am 12:07 AM

pythonloopscanleadtoerrorslikeinfiniteloops,modifyingListsDuringteritation,逐个偏置,零indexingissues,andnestedloopineflinefficiencies

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。