250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- Til
- f-string
- map
- 한줄for문
- 내배캠_학습기록
- ★
- 태블로
- 프로그래머스
- 내일배움일지
- 내일배움캠프
- 통계학
- 데이터시각화
- SQLD
- AB테스트
- DATE_SUB
- Join
- 가설검정
- 데이터전처리
- Set
- 이중for문
- SQL
- Leetcode
- Max
- 아티클스터디
- python
- 다중공선성
- 반복문
- 리스트
- 시각화
- 선형회귀
Archives
- Today
- Total
노력에는 지름길이 없으니까요
프로그래머스 - 이진 변환 반복하기 Python ver. 본문
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
반응형
'Python > 프로그래머스' 카테고리의 다른 글
프로그래머스 - 분수의 덧셈 Python ver. (0) | 2024.07.08 |
---|---|
프로그래머스 - 명예의 전당 (1) Python ver. (0) | 2024.07.05 |
(★)프로그래머스 - 문자열 내 마음대로 정렬하기 Python ver. (0) | 2024.07.05 |
프로그래머스 - 문자열안에 문자열 Python ver. (0) | 2024.07.04 |
프로그래머스 - 푸드 파이트 대회 Python ver. (0) | 2024.07.04 |