0

私の問題は、リスト (list[2:5] など) をスライスすることよりもメソッドにあると思います。コードが実際に実行されているとき、正しい場所でリストを切り取っていません。プログラムは、ユーザーから与えられた数字を推測しようとしています。random モジュールを使用してこれを行っていますが、これは最善の方法ではないかもしれませんが、実験していました。

コード:

import random

number = input('Pick a number from 1-100 for the computer to guess, \nand find out how many tries it takes the computer: ')

print number

possibilities = range(101)

del possibilities[0]

tries = 1

guess = random.choice(possibilities)

print "\n", guess

while guess != number:
    if guess > number:
        possibilities = possibilities[:(guess-1)]
    else:
        possibilities = possibilities[(guess-1):]
    print possibilities
    guess = random.choice(possibilities)
    print guess
    tries += 1

エラーの例:

上記の print ステートメントからのプログラムの出力。また、常に誤動作するわけではなく、約 50 ~ 60% の確率で正常に動作することにも言及したいと思います。また、入力した数字だけではありません。たとえば、45 は正常に動作する場合もあれば、以下のように失敗する場合もあります。かなりランダムに発生するようです。

初期入力 45 の場合:

45

30 [30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, [79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100]

88 初期エラー(プログラムは 88 を過ぎたリストを削除する必要があります) [30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97、98、99、100]

54 [30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82] 40 致命的なエラー(リストを切り取って、「探していた」番号を削除した場所) [69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82] 72 [69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82]

初期入力 6 の場合:

6

48
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47]
9
[1, 2, 3, 4, 5, 6, 7, 8]

5  **Initial Error** (the program should have eliminated 5 from the list below this line)
[5, 6, 7, 8]

5  **Fatal Error** (the program deleted the rest of the list)
[]

Traceback (most recent call last):
  File "C:\Users\Joseph\Documents\Programming fun\computer guessing a number game.py", line 32, in <module>
    guess = random.choice(possibilities)
  File "C:\Python27\lib\random.py", line 274, in choice
    return seq[int(self.random() * len(seq))]  # raises IndexError if seq is empty
IndexError: list index out of range

Python がこれを行っている理由と、回避可能かどうかを知りたいです。私のコードに問題があるとは思いません。Python が想定どおりに動作していないように見えますが、私はプログラミングに非常に慣れていないので、何かが欠けているかどうかはわかりません。

提供される可能性のあるヘルプに感謝します。

4

4 に答える 4

2

を行うguess = random.choice(possibilities)と、リストから値を取得しますが、これを行うと、それをインデックスとして使用しますpossibilities = possibilities[:(guess-1)]。ループを数回繰り返した後、リストにインデックスの範囲外の値が含まれています。

[80, 81, 82, 83, 84, 85, 86, 87]

ここから値 (85 など) を選択してから を実行するとpossibilities = possibilities[85:]、空のリストが返されます。

インデックスに固執する必要があります。

于 2012-06-30T02:14:41.353 に答える
1

possibilitiesの値とそのインデックスを混同しています。mylist[:i]「値 i を持つ要素まで」ではなく、「i 番目の要素までの mylist 内のすべての値」を意味します。

最初は、インデックスと値を混同しても問題は発生しません。これは、リストの値が (0 をスキップするため、ほとんど) インデックスと等しいためです。しかし、リストの一部を切り取り始めると、リストがその中のいくつかの値よりも短いという状況が発生します。たとえば、80 未満の要素がすべて削除され、90 と推測された場合、possibilities[90:]は長さ 20 のリストから 90 番目以降の要素にアクセスしようとします。もちろん、これは機能しません。

代わりにこれを試してください:

i = possibilities.index(guess)    
possibilities = possibilities[:(i-1)]
于 2012-06-30T02:17:24.883 に答える
0

「5」を選択すると、このコードは 5 番目以降の位置から削除されます。配列には要素が 4 つしかないため、すべてを意味します。

于 2012-06-30T02:14:55.633 に答える
0

スライスは、要素の値ではなくインデックスによって定義されます。th 項目の後に th 項目が続くがth 項目を含まないx[a:b]リストを与えるリストのスライスがある場合。が以下の場合、結果は空になります。がリスト内の項目数以上の場合、 th の後のすべての項目が含まれます。最初の数値を省略すると 0 が想定され、2 番目の数値を省略するとリスト内の項目数が想定されます。混乱を避けるために、リストに数字を使用しない例を次に示します。aa+1bbaba

x = ['a','b','c','d','e','f','g']
print x[3:] # prints ['d','e','f','g']
print x[:2] # prints ['a','b']
print x[1:4] # prints ['b','c','d']

スライスで負の数を使用すると、リストの長さが数値に追加されて、最終的なインデックスが決定されます。

コードを正しく動作させ、スライスを使用して可能性のリストを絞り込むためにindex、引数として渡された項目のインデックス (もちろん) を与えるリストのメソッドがあります。したがって、プログラムでは、行を変更して読み取ることができます

if guess > number:
    possibilities = possibilities[:possibilities.index(guess)]
else:
    possibilities = possibilities[possibilities.index(guess):]

数を推測するタイプのプログラムを作成するためのより良い方法は、代わりに 2 つの変数のみを使用することですhi。これらの変数loは、答えとなりうる最大の数と最小の数をそれぞれ追跡します。答えが推測よりも大きい場合はlo、推測に 1 を加えた値に設定し、答えが推測よりも小さい場合は、推測にhi1 を引いた値に設定します。

于 2012-06-30T02:25:14.613 に答える