好钥匙

WBOY
WBOY原创
2024-08-19 16:34:501070浏览

Good keys

每周挑战 282

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

挑战,我的解决方案

任务 1:好整数

任务

给你一个正整数 $int,有 3 位或更多位。

编写一个脚本以返回给定整数中的好整数,如果没有找到则返回 -1。一个好的整数是恰好三个连续的匹配数字。

我的解决方案

我原本以为这个任务可以用正则表达式模式来完成,但看来我错了。我会看看其他 TPW 成员是否可以这样做。

对于这个任务,我有一个变量 pos,它从 0 迭代到小于字符串长度的 3。然后我检查四件事:

  1. 当前位置的数字与下一个位置的数字相同。
  2. 当前位置的数字与下一个位置的数字相同。
  3. 位置为 0(表示当前数字之前没有数字)或前一个数字与当前数字不同。
  4. 位置比长度少3(表示当前三位数之后没有数字)或者下第三个数字与当前数字不同。

如果这些都是真的,我会返回这三位数字。在 Python 中,这是作为字符串完成的,因为“000”不是真正的整数。如果迭代器耗尽,我返回 -1。

def good_integer(n: int) -> str:
    value = str(n)
    length = len(value)

    for pos in range(length-2):
        if (
            value[pos] == value[pos+1]
            and value[pos] == value[pos+2]
            and (pos == 0 or value[pos] != value[pos-1])
            and (pos + 3 == length or value[pos] != value[pos+3])
        ):
            return value[pos:pos+3]

    return '-1'

示例

$ ./ch-1.py 12344456
444

$ ./ch-1.py 1233334
-1

$ ./ch-1.py 10020003
000

任务 2:更改密钥

任务

您将获得一个由用户输入的字母字符串 $str。

编写一个脚本来查找用户必须更改键才能键入给定字符串的次数。更改密钥被定义为使用与上次使用的密钥不同的密钥。 “shift”和“caps lock”键不计算在内。

我的解决方案

有趣的事实。当我得到一个新键盘(每隔几年)时,我会看到我需要多长时间才能将大写锁定键撕下来。大多数键盘都撑不了一天!

对于此任务,我将字符串转换为小写并从两个变量开始。 current_key 值是当前按下的键,并使用输入的第一个字母进行初始化。 Changes 变量是我所做的关键更改的数量,从 0 开始。

然后我循环遍历输入字符串中的每个字母。如果该字母与 current_key 不同,我会用新字母更新它,并将更改增加 1。

def key_changes(s: str) -> int:
    s = s.lower()
    current_key = s[0]
    changes = 0

    for letter in s:
        if letter != current_key:
            current_key = letter
            changes += 1

    return changes

示例

$ ./ch-2.py pPeERrLl
3

$ ./ch-2.py rRr
0

$ ./ch-2.py GoO
1

以上是好钥匙的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn