일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- backjoon
- 정규식
- BFS
- lambda
- programmers
- dfs
- 파이썬
- 백준
- 이분탐색
- 추석맞이 코딩챌린지
- 정렬
- Re
- Combinations
- Zip
- 동적 계획법
- 자바
- KAKAO BLIND RECRUITMENT
- 재귀함수
- python
- 프로그래머스
- java
- 그리디
- 다익스트라
- heapq
- 수학
- 카카오
- Set
- DateTime
- 위클리 챌린지
- divmod
Archives
- Today
- Total
상상쓰
[프로그래머스] 2개 이하로 다른 비트 본문
https://programmers.co.kr/learn/courses/30/lessons/77885
쉽다. 짝수일 때 이진수는 0 으로 끝나기 때문에 + 1 을 해주면 된다. 홀수일 때는 2가지 경우의 수를 두어 잘 풀면 된다.
파이썬에 내장된 함수를 통하여 쉽게 진수 변환을 할 수 있다.
def solution(numbers):
answer = []
for i in numbers:
if i % 2 == 0:
answer.append(i + 1)
else:
b = bin(i)[2:]
b = list(b)
for j in range(len(b)-1, -1, -1):
if b[j] == '0':
b[j] = '1'
b[j+1] = '0'
b[0] = '0b' + b[0]
break
if j == 0 and b[j] == '1':
b[0] = '0b10'
break
answer.append(int(''.join(b), 2))
return answer
print(solution([2, 7])) # [3, 11]
'Coding Test' 카테고리의 다른 글
[프로그래머스] 모두 0으로 만들기 (0) | 2021.05.27 |
---|---|
[프로그래머스] 약수의 개수와 덧셈 (0) | 2021.05.26 |
[프로그래머스] 순위 검색 (0) | 2021.05.25 |
[프로그래머스] 110 옮기기 (0) | 2021.05.24 |
[프로그래머스] 정수 삼각형 (0) | 2021.05.21 |
Comments