노력에는 지름길이 없으니까요

프로그래머스 - 이진 변환 반복하기 Python ver. 본문

Python/프로그래머스

프로그래머스 - 이진 변환 반복하기 Python ver.

데건 2024. 7. 5. 13:50
728x90

 

해결일 언어 레벨 테스트명
20240705 Python level 1  이진 변환 반복하기

 

링크 : https://school.programmers.co.kr/learn/courses/30/lessons/70129

 

 


 

내 코드

def solution(s):
    count, turn = 0, 0
    while True :
        count += s.count('0')
        s = s.replace('0','')
        s = format(len(s), 'b')
        turn += 1
        if s == '1': return [turn, count]

 

def solution(s):
    count, turn = 0, 0
    while s != '1' :
        count += s.count('0')
        s = s.replace('0','')
        s = format(len(s), 'b')
        turn += 1
    return [turn, count]

 

개선점:

조건은 s가 '1'이 될 때까지 반복인데!!!

문제를 잘못 읽어서 계속 시간을 바닥에 버리고 있었다

하... 이런 바보 같은 실수는 다시는 하지 말아야지 다시는!!

 

베스트 코드

def solution(s):
    a, b = 0, 0
    while s != '1':
        a += 1
        num = s.count('1')
        b += len(s) - num
        s = bin(num)[2:]
    return [a, b]

 

이 코드의 본받을 점은...

굳이 s를 몇번이고 다시 선언하지 않고 (나는 두번함)

한번만에 마무리를 지었다는 것인데

이 부분에서 갈린 것 같다...

num = s.count('1')
b += len(s) - num

 

len(s)를 유용하게 사용할 수 있었는데!

728x90
반응형