-
카테고리
-
세부 분야
알고리즘 · 자료구조
-
해결 여부
미해결
선생님 이렇게 했을 때 왜 답이 안 나오는지 모르겠습니다.
20.01.04 20:32 작성 조회수 73
0
a, b = map(int, input().split())
ch = [0]*b
answerlist = []
def fun(v):
if v == b:
#print(ch)
#print(answerlist, 'xmr')
if sorted(ch) not in answerlist:
#print(ch, 1)
#print(answerlist, 2)
answerlist.append(ch)
#print(answerlist, 3)
return
else:
for i in range(a):
if i+1 in ch:
continue
ch[v]=i+1
fun(v+1)
fun(0)
#print(answerlist)
for i in answerlist:
for j in i:
print(j, end=' ')
print()
#을 모두 풀었을 떄 (4, 2)의 output이
[1, 2] [] xmr [1, 2] 1 [] 2 [[1, 2]] 3 [1, 3] [[1, 3]] xmr $$여기서 프린트되는 answerlist가왜 [[1, 2], [1, 3]]이아니라 [[1, 3]]인지 모르겠습니다. [1, 4] [[1, 4]] xmr [2, 1] [[2, 1]] xmr [2, 1] 1 [[2, 1]] 2 [[2, 1], [2, 1]] 3 [2, 3] [[2, 3], [2, 3]] xmr [2, 4] [[2, 4], [2, 4]] xmr [3, 1] [[3, 1], [3, 1]] xmr [3, 1] 1 [[3, 1], [3, 1]] 2 [[3, 1], [3, 1], [3, 1]] 3 [3, 2] [[3, 2], [3, 2], [3, 2]] xmr [3, 2] 1 [[3, 2], [3, 2], [3, 2]] 2 [[3, 2], [3, 2], [3, 2], [3, 2]] 3 [3, 4] [[3, 4], [3, 4], [3, 4], [3, 4]] xmr [[3, 4], [3, 4], [3, 4], [3, 4]] 3 4 3 4 3 4 3 4
answerlist가 새로운 것들로 계속 append되는게 아니라 리셋이 되나요?
부탁드립니다....!
답변을 작성해보세요.
1
김태원
지식공유자2020.01.04
파이썬 내부 메모리 관리의 문제인것 같습니다. 이유는 저도 모르겠습니다.
아래와 같이 고치면 답은 나옵니다.
def fun(v):
if v == b:
tmp=[]
for x in ch:
tmp.append(x)
tmp.sort()
if tmp not in answerlist:
answerlist.append(tmp)
print(answerlist)
else:
for i in range(a):
if i+1 in ch:
continue
ch[v]=i+1
fun(v+1)
a, b = map(int, input().split())
ch = [0]*b
answerlist = []
fun(0)
for i in answerlist:
for j in i:
print(j, end=' ')
print()
0
답변 2