好钥匙
每周挑战 282
穆罕默德·s·安瓦尔 (mohammad s. anwar) 每周都会发出“每周挑战”,为我们所有人提供了为两周任务提出解决方案的机会。我的解决方案首先用python编写,然后转换为perl。这对我们所有人来说都是练习编码的好方法。
挑战,我的解决方案
任务 1:好整数
任务
给你一个正整数 $int,有 3 位或更多位。
编写一个脚本以返回给定整数中的好整数,如果没有找到则返回-1。一个好的整数是恰好三个连续的匹配数字。
我的解决方案
我原本以为这个任务可以用正则表达式模式来完成,但看来我错了。我会看看其他 tpw 成员,看看他们是否可以这样做。
对于这个任务,我有一个变量 pos,它从 0 迭代到小于字符串长度的 3。然后我检查四件事:
- 当前位置的数字与下一个位置的数字相同。
- 当前位置的数字与下一个第二位置的数字相同。
- 位置为0(表示当前数字之前没有数字)或者前一个数字与当前数字不同。
- 位置比长度少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 12344456444$ ./ch-1.py 1233334-1$ ./ch-1.py 10020003000
任务 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 pPeERrLl3$ ./ch-2.py rRr0$ ./ch-2.py GoO1