Project Eulerを使用してプログラミングを行っていますが、奇妙な問題に遭遇しました。2 つの自然数から (自然) 数を生成するすべての可能な方法を見つけたいと考えています。奇妙な結果に気付いた単純なループを作成しました。たとえば、1 は 3 と 1 から生成されました。調査の結果、次のようになりました。
#Importing stuff I often use in my solutions/tests
from math import sqrt, log, floor, pow, fabs, factorial
from sets import Set
from random import randint
from itertools import permutations
import sys
dub = dict()
c = 0 #Counting the number of elements in dub[18], use to track changes
for i in range (1,10):
if 18 in dub: #setting c = len(dub[18])
c = len(dub[18])
for j in range (i+1,10):
pair = [[i,j]]
v = i+j
if v in dub:
dub[v].append(pair[0])
else:
dub[v] = pair
v = i*j
if v in dub:
dub[v].append(pair[0])
else:
if i == 3 and j == 8: print 'here', v # The value that is added to dub[18] instead of dub[24]
dub[v] = pair
if 18 in dub and not c == len(dub[18]): #This is how I found that something is wrong.
c = len(dub[18])
print dub[18]
print v,i,j
raw_input()
これでどの結果が得られますか:
[[2, 9]]
18 2 9
[[2, 9], [3, 6]]
18 3 6
here 24
[[2, 9], [3, 6], [3, 8]]
24 3 8
私が使用するはずのキーは 24 ですが、リストはキー 18 の下に配置されています。なぜですか?