• 카테고리

    질문 & 답변
  • 세부 분야

    알고리즘 · 자료구조

  • 해결 여부

    미해결

선생님 이렇게 했을 때 왜 답이 안 나오는지 모르겠습니다.

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되는게 아니라 리셋이 되나요?

부탁드립니다....!

답변 2

·

답변을 작성해보세요.

1

파이썬 내부 메모리 관리의 문제인것 같습니다.  이유는 저도 모르겠습니다.

아래와 같이 고치면 답은 나옵니다. 

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

넵 감사합니다!