好钥匙(钥匙...)

wufei1232024-08-19python30

好钥匙

每周挑战 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

以上就是好钥匙的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。