반응형
문제 설명: 약수의 개수가 세 개 이상인 수를 합성수라고 합니다. 자연수 n이 매개변수로 주어질 때 n이하의 합성수의 개수를 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ n ≤ 100
문제 해결
def solution(n):
answer = 0
for i in range(4, n + 1):
for j in range(2, int(i ** 0.5) + 1):
if i % j == 0:
answer += 1
break
return answer
주석: 1과 자신을 제외한 최소 하나의 약수만 발견되면 합성수이므로 4부터 n까지의 각 수(i)에 대해 2부터 i의 제곱근(i**0.5) 사이의 나누어떨어지는 수가 있는지 확인 후 1개라도 발견하면 즉시 중단(break)하여 연산을 최적화한다.
반응형
'코딩_Python(Level.0)' 카테고리의 다른 글
| [Level.0] 빈 배열에 추가, 삭제하기 (0) | 2026.03.17 |
|---|---|
| [Level.0] 중복된 문자 제거 (0) | 2026.03.17 |
| [Level.0] 글자 지우기 (0) | 2026.03.17 |
| [Level.0] 날짜 비교하기 (0) | 2026.03.16 |
| [Level.0] 등차수열의 특정한 항만 더하기 (0) | 2026.03.16 |