Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- Real or Not? NLP with Disaster Tweets
- 금융문자분석경진대회
- 백준
- SW Expert Academy
- 더현대서울 맛집
- 코로나19
- AI 경진대회
- 프로그래머스
- gs25
- 자연어처리
- Git
- 편스토랑
- dacon
- hackerrank
- 데이콘
- 파이썬
- 편스토랑 우승상품
- ChatGPT
- leetcode
- PYTHON
- 우분투
- 맥북
- Docker
- Baekjoon
- programmers
- Kaggle
- github
- 캐치카페
- ubuntu
- 프로그래머스 파이썬
Archives
- Today
- Total
솜씨좋은장씨
[Programmers] 다음 큰 숫자 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 프로그래머스의 다음 큰 숫자 입니다.
코딩테스트 연습 - 다음 큰 숫자
자연수 n이 주어졌을 때, n의 다음 큰 숫자는 다음과 같이 정의 합니다. 조건 1. n의 다음 큰 숫자는 n보다 큰 자연수 입니다. 조건 2. n의 다음 큰 숫자와 n은 2진수로 변환했을 때 1의 갯수가 같습니
programmers.co.kr
Solution
def solution(n):
answer = 0
one_count = bin(n).count("1")
for num in range(n+1, 1000001):
num_one_count = bin(num).count("1")
if one_count == num_one_count:
answer = num
break
return answer
Solution 풀이
이 문제는 이진수로 변환하였을때 입력한 수와 1의 개수는 같으면서 다음으로 큰 숫자를 찾는 문제 입니다.
먼저 입력받은 수를 bin을 활용하여 이진수로 변환한 뒤 1의 개수를 count("1")로 세어줍니다.
이제 입력받은 n 보다 더 크면서 1000000보다 작은 숫자를 찾아야하므로 반복문을 돌면서 찾습니다.
범위는 n+1 부터 1000000 까지!
이제 각각의 숫자를 bin을 활용하여 이진수로 바꾼다음 1의 개수를 세고
그 수가 아까 세어둔 수와 같다면! 정답에 넣어주고 반복문을 종료합니다.
SOMJANG/CODINGTEST_PRACTICE
1일 1문제 since 2020.02.07. Contribute to SOMJANG/CODINGTEST_PRACTICE development by creating an account on GitHub.
github.com
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaekJoon] 2753번 : 윤년 (Python) (0) | 2021.06.11 |
---|---|
[Programmers] 최대공약수와 최소공배수 (Python) (1) | 2021.06.10 |
[Programmers] 구명보트 (Python) (0) | 2021.06.08 |
[Programmers] 2개 이하로 다른 비트 (Python) (0) | 2021.06.07 |
[BaekJoon] 1085번 : 직사각형에서 탈출 (Python) (0) | 2021.06.06 |
Comments