良い鍵

WBOY
WBOYオリジナル
2024-08-19 16:34:50903ブラウズ

Good keys

ウィークリーチャレンジ 282

Mohammad S. Anwar は毎週、毎週 2 つのタスクに対する解決策を全員が考え出すチャンスであるウィークリー チャレンジを送信します。私のソリューションは最初に Python で書かれ、次に Perl に変換されます。これは、私たち全員がコーディングを練習するのに最適な方法です。

挑戦、私の解決策

タスク 1: 適切な整数

タスク

3 桁以上の正の整数 $int が与えられます。

指定された整数で適切な整数を返すか、見つからない場合は -1 を返すスクリプトを作成します。適切な整数とは、正確に 3 つの連続する一致する数字です。

私の解決策

当初、このタスクは正規表現パターンを使用して実行できると考えていましたが、間違っていたようです。他のTPWメンバーがそのようにできるかどうか見てみるつもりです。

このタスクでは、0 から文字列の長さの 3 未満まで反復する変数 pos を使用します。次に、次の 4 つのことを確認します。

  1. 現在の位置の数字は次の位置の数字と同じです。
  2. 現在の位置の数字は、2 つ前の位置の数字と同じです。
  3. 位置が 0 (現在の桁の前に桁がないことを意味します) であるか、前の桁が現在の桁と同じではありません。
  4. 位置が長さより 3 少ない (つまり、現在の 3 桁の後に桁がない) か、次の 3 番目の桁が現在の桁と同じではありません。

これらがすべて真であれば、その 3 桁を返します。 「000」は実際の整数ではないため、これは Python では文字列として行われます。イテレータが使い果たされた場合は、-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」キーはカウントされません。

私の解決策

面白い事実。新しいキーボードを購入するとき (数年ごと)、Caps Lock キーを引き抜くまでにどれくらい時間がかかるかを確認します。ほとんどのキーボードは 1 日も持ちません!

このタスクでは、文字列を小文字に変換し、2 つの変数から開始します。 current_key 値は現在押されているキーであり、入力の最初の文字で初期化されます。変更変数は、私が行った重要な変更の数で、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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。