巡回セールスマン問題を解いていて、距離の総和を出したいです。
問題は巡回セールスマン問題とは関係ないです。
下のソースは途中からです。
もともとNextというリストに、次とずれる地点の数字が入っています。
sumd2で総和を計算しているのですが、新しい経路のたびにsumd2を計算したいです。
しかし、for j の下に入れるとout of rangeのエラーが出てしまいます。
for i の下なら出ません。
どう直したらよいでしょうか
実際にはsumd2=0は片方ずつしか入れていません
発生している問題・エラーメッセージ
if i!=j and j!=Next[i]: IndexError: list index out of range
python
1for i in range(6): 2 sumd2=0 3 for j in range(5): 4 sumd2=0 5 if i!=j and j!=Next[i]: 6 newnext[j]=Next.index(j) 7 tmp2=newnext[j] 8 tmp=j 9 while tmp2!=Next[i]: 10 tmp=Next.index(tmp) 11 newnext[tmp]=Next.index(tmp) 12 tmp2=Next.index(tmp) 13 newnext[i]=j 14 newnext[Next.index(tmp)]=Next[j] 15 for k in range(len(X)-1): 16 sumd2+=distance(X[newnext[k]],X[newnext[k+1]],Y[newnext[k]],Y[newnext[k+1]]) 17 sumd2+=distance(X[newnext[k]],X[newnext[0]],Y[newnext[k]],Y[newnext[0]]) 18 if sumd2<sumd: 19 Next=newnext 20 sumd=sumd2 21 else: 22 newnext.clear() 23 for l in range(len(Next)): 24 newnext.append(Next[l]) 25 26print(sumd2)