1

重複の可能性:
Pythonを使用したCaesar's Cipherは、少し助けになる可能性があります

さて、私のクラスでは、辞書をシーザー暗号としてシフトするコードを書くことになっています。私のコードはすべてうまくシフトしますが、提供されたテスト ケースとは異なる順序でキーを返します。

私のコード:

sLowerCase = string.ascii_lowercase
sUpperCase = string.ascii_uppercase
dCode = {'A':'A', 'B':'B', 'C':'C', 'D':'D', 'E':'E', 'F':'F', 'G':'G', 'H':'H', 'I':'I', 'J':'J', 'K':'K', 'L':'L', 'M':'M', 'N':'N', 'O':'O', 'P':'P', 'Q':'Q', 'R':'R', 'S':'S', 'T':'T', 'U':'U', 'V':'V', 'W':'W', 'X':'X', 'Y':'Y', 'Z':'Z',
         'a':'a', 'b':'b', 'c':'c', 'd':'d', 'e':'e', 'f':'f', 'g':'g', 'h':'h', 'i':'i', 'j':'j', 'k':'k', 'l':'l', 'm':'m', 'n':'n', 'o':'o', 'p':'p', 'q':'q', 'r':'r', 's':'s', 't':'t', 'u':'u', 'v':'v', 'w':'w', 'x':'x', 'y':'y', 'z':'z'}

for c in dCode.keys():

    if c in sUpperCase:

        if sUpperCase.index(c) + shift > 25:

            dCode[c] = sUpperCase[(sUpperCase.index(c) + shift) - 26]

        else:

            dCode[c] = sUpperCase[(sUpperCase.index(c) + shift)]

    if c in sLowerCase:

        if sLowerCase.index(c) + shift > 25:

            dCode[c] = sLowerCase[(sLowerCase.index(c) + shift) - 26]

        else:

            dCode[c] = sLowerCase[(sLowerCase.index(c) + shift)]

return dCode

buildCoder(0) の私の出力 (明らかに最も読みやすい)

{'B': 'B', 'D': 'D', 'F': 'F', 'H': 'H', 'J': 'J', 'L': 'L', ' N': 'N', 'P': 'P', 'R': 'R', 'T': 'T', 'V': 'V', 'X': 'X', 'Z' : 'Z', 'b': 'b', 'd': 'd', 'f': 'f', 'h': 'h', 'j': 'j', 'l': ' l'、'n': 'n'、'p': 'p'、'r': 'r'、't': 't'、'v': 'v'、'x': 'x' , 'z': 'z', 'A': 'A', 'C': 'C', 'E': 'E', 'G': 'G', 'I': 'I', ' K': 'K', 'M': 'M','O': 'O', 'Q': 'Q', 'S': 'S', 'U': 'U', 'W': 'W', 'Y': 'Y', 'a ': 'a', 'c': 'c', 'e': 'e', 'g': 'g', 'i': 'i', 'k': 'k', 'm': 'm', 'o': 'o', 'q': 'q', 's': 's', 'u': 'u', 'w': 'w', 'y': 'y '}'q': 'q', 's': 's', 'u': 'u', 'w': 'w', 'y': 'y'}'q': 'q', 's': 's', 'u': 'u', 'w': 'w', 'y': 'y'}

彼らの出力:

{'A': 'A', 'C': 'C', 'B': 'B', 'E': 'E', 'D': 'D', 'G': 'G', ' F': 'F', 'I': 'I', 'H': 'H', 'K': 'K', 'J': 'J', 'M': 'M', 'L' : 'L', 'O': 'O', 'N': 'N', 'Q': 'Q', 'P': 'P', 'S': 'S', 'R': ' R'、'U': 'U'、'T': 'T'、'W': 'W'、'V': 'V'、'Y': 'Y'、'X': 'X' , 'Z': 'Z', 'a': 'a', 'c': 'c', 'b': 'b', 'e': 'e', 'd': 'd', ' g': 'g', 'f': 'f','i': 'i', 'h': 'h', 'k': 'k', 'j': 'j', 'm': 'm', 'l': 'l', 'o ': 'o', 'n': 'n', 'q': 'q', 'p': 'p', 's': 's', 'r': 'r', 'u': 'u'、't': 't'、'w': 'w'、'v': 'v'、'y': 'y'、'x': 'x'、'z': 'z '}'w': 'w', 'v': 'v', 'y': 'y', 'x': 'x', 'z': 'z'}'w': 'w', 'v': 'v', 'y': 'y', 'x': 'x', 'z': 'z'}

私はすでにPythonを使用してテストと比較を行ってきましたが、それらは実際には同じキーと値で構成される辞書です。どんなアドバイスも素晴らしいでしょう。(これはオンラインの MIT クラス用です。通常はフォーラムがありますが、試験がある間はフォーラムがダウンしています。これは試験用ではありません。

4

2 に答える 2

3

Python の辞書は、特定の順序を保持しません。そのため、キーと値が (a) 最初に作成された順序、または (b) 最後に更新された順序で読み取られるかどうかはわかりません。

明らかに、2 つの辞書は同じですが。

編集: dict1 == dict22 つの辞書が同じかどうかを証明するには十分です。各キー/値をピースごとにチェックする必要はありません。

于 2012-11-04T07:07:14.470 に答える
1

別の注意として、の%代わりにモジュラス演算子を使用する必要があり- 26ます。

交換

    if sUpperCase.index(c) + shift > 25:

        dCode[c] = sUpperCase[(sUpperCase.index(c) + shift) - 26]

    else:

        dCode[c] = sUpperCase[(sUpperCase.index(c) + shift)]

    dCode[c] = sUpperCase[(sUpperCase.index(c) + shift) % 26]
于 2012-11-04T07:34:19.920 に答える