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
- gs25
- 자연어처리
- Docker
- 프로그래머스
- programmers
- Baekjoon
- hackerrank
- ChatGPT
- 캐치카페
- 금융문자분석경진대회
- SW Expert Academy
- leetcode
- ubuntu
- 편스토랑
- 백준
- 더현대서울 맛집
- 코로나19
- 우분투
- github
- 데이콘
- Git
- 맥북
- 파이썬
- 프로그래머스 파이썬
- Kaggle
- PYTHON
- Real or Not? NLP with Disaster Tweets
- dacon
- AI 경진대회
- 편스토랑 우승상품
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 4673번 : 셀프 넘버 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 백준의 셀프 넘버 입니다.
👨🏻💻 문제 풀이
셀프 넘버란! 생성자가 없는 숫자입니다.
생성자가 있는 숫자란 무엇인가!
생성자가 있는 숫자 = 숫자 + 숫자의 각 자리 수
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)
'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 |
Comments