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 |
Tags
- Baekjoon
- 우분투
- Kaggle
- github
- 데이콘
- hackerrank
- Real or Not? NLP with Disaster Tweets
- 편스토랑
- 프로그래머스 파이썬
- 자연어처리
- 편스토랑 우승상품
- Git
- 코로나19
- SW Expert Academy
- PYTHON
- 백준
- 금융문자분석경진대회
- 더현대서울 맛집
- dacon
- 파이썬
- programmers
- leetcode
- 프로그래머스
- 맥북
- 캐치카페
- AI 경진대회
- gs25
- Docker
- ChatGPT
- ubuntu
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 4673번 : 셀프 넘버 (Python) 본문
728x90
반응형

코딩 1일 1문제! 오늘의 문제는 백준의 셀프 넘버 입니다.
4673번: 셀프 넘버
셀프 넘버는 1949년 인도 수학자 D.R. Kaprekar가 이름 붙였다. 양의 정수 n에 대해서 d(n)을 n과 n의 각 자리수를 더하는 함수라고 정의하자. 예를 들어, d(75) = 75+7+5 = 87이다. 양의 정수 n이 주어졌을 때,
www.acmicpc.net
👨🏻💻 문제 풀이
셀프 넘버란! 생성자가 없는 숫자입니다.
생성자가 있는 숫자란 무엇인가!
생성자가 있는 숫자 = 숫자 + 숫자의 각 자리 수
34의 경우
26 + 2 + 6 == 34 이므로
34의 생성자는 26이 됩니다.
이 문제에서 구해야하는 답은 10,000이하의 숫자 중에서 생성자가 없는 셀프 넘버 입니다.
문제를 푸는 방식은 먼저 1~10000 사이의 숫자를 활용하여 생성자가 있는 숫자를 모두 만든 다음
non_self_numbers = set()
for num in range(1, 10001):
for each_num in str(num):
num += int(each_num)
non_self_numbers.add(num)
1~10000 사이의 전체 숫자에서 생성자가 있는 숫자를 제거하여 셀프넘버만 구하는 식으로 구했습니다.
range_numbers = set(range(1, 10001))
sorted(range_numbers - non_self_numbers)
전체 코드는 아래를 참고해주세요.
👨🏻💻 코드 ( Solution )
def self_number():
range_numbers = set(range(1, 10001))
non_self_numbers = set()
for num in range(1, 10001):
for each_num in str(num):
num += int(each_num)
non_self_numbers.add(num)
return sorted(range_numbers - non_self_numbers)
if __name__ == "__main__":
self_numbers = self_number()
for self_num in self_numbers:
print(self_num)
GitHub - SOMJANG/CODINGTEST_PRACTICE: 1일 1문제 since 2020.02.07
1일 1문제 since 2020.02.07. Contribute to SOMJANG/CODINGTEST_PRACTICE development by creating an account on GitHub.
github.com
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[Programmers] 탐욕법(Greedy) - 단속카메라 (Python) (0) | 2022.03.01 |
---|---|
[BaekJoon] 2525번 : 오븐 시계 (Python) (0) | 2022.02.28 |
[BaekJoon] 10699번 : 오늘 날짜 (Python) (0) | 2022.02.26 |
[BaekJoon] 11718번 : 그대로 출력하기 (Python) (0) | 2022.02.25 |
[BaekJoon] 11931번 : 수 정렬하기 4 (Python) (0) | 2022.02.25 |