맛동산

(파이썬)백준 알고리즘 1463번 1로 만들기 본문

파이썬/알고리즘

(파이썬)백준 알고리즘 1463번 1로 만들기

오지고지리고알파고포켓몬고 2017. 5. 28. 21:29

백준 알고리즘 저지 1463번 문제 (https://www.acmicpc.net/problem/1463)

 

 

1, 2, 3번 방법을 조합하여 1을 만드는 문제.

가장 적은 횟수를 찾는 문제인데 나는 1, 2, 3번 방법을 저장하고 중복을 제거하고, 그 결과에 대한 1, 2, 3을 수행하고 ... 1이 나오면 멈추도록함.

최적해의 시간 복잡도는 잘 모르겠지만 그에 비에 공간 복잡도가 안좋게 설계 된 코드일듯..

 

훗날 더 좋은 방법이 떠오르길

 

 
Q=[int(input())]
count=0
def doit(Qu):
    temp=[]
    for i in Qu:
        temp.append(i-1)
        if i%3==0:
            temp.append(i/3)
        if i%2==0:
            temp.append(i/2)
    temp=set(temp)
    temp=list(temp)
    return temp

while True:
    temp=Q[:]
    Q=[]
    Q=doit(temp)
    count+=1
    if min(Q)==1:
        break
print(count)

Comments