Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 그리디
- ubuntu
- C++
- CS231n
- ssd
- 파이썬
- 3단계
- 구현
- 백준
- 모두를 위한 딥러닝 강좌 시즌1
- SWEA
- cs
- test-helper
- 딥러닝
- 전산기초
- Object detection
- 이것이 코딩테스트다 with 파이썬
- MySQL
- AWS
- Python
- 머신러닝
- pytorch
- 실전알고리즘
- 2단계
- docker
- 1단계
- STL
- 코드수행
- 프로그래머스
- 자료구조 및 실습
Archives
- Today
- Total
곰퓨타의 SW 이야기
[프로그래머스 level1 약수의 개수와 덧셈] 완전제곱수 활용하기 본문
해결해야하는 문제는 다음과 같았다.
https://programmers.co.kr/learn/courses/30/lessons/77884
코딩테스트 연습 - 약수의 개수와 덧셈
두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주
programmers.co.kr
math를 import하여 left부터 right까지 숫자를 하나씩 확인하며, 완전 제곱수인 경우에는 약수가 홀수개 이므로 수를 빼주고,
완전 제곱수가 아닌 경우에는 약수가 짝수개이므로 더할 수 있도록 하였다.
import math
def solution(left, right):
answer = 0
# 제곱수는 약수가 홀수개, 제곱수가 아니라면 약수는 짝수개
for i in range(left, right+1):
if math.sqrt(i)-int(math.sqrt(i)) == 0:
answer -= i
else :
answer += i
return answer
다른 사람의 풀이를 보니 math.sqrt(i) 는 i**0.5 라고 하여 math 를 import 하지 않아도 된다는 것을 다시 한번 생각해볼 수 있었다.
'TIL > 프로그래머스' 카테고리의 다른 글
[프로그래머스 level2 행렬 테두리 회전하기] 시간 초과 극복하기 (0) | 2021.06.11 |
---|---|
[프로그래머스 level2 게임 맵 최단거리] 효율적으로 bfs 활용하기 (0) | 2021.06.10 |
[프로그래머스 level1 이름이 있는 동물의 아이디] mysql 기초지식 활용하기 (0) | 2021.06.10 |
[프로그래머스 level1 로또의 최고순위와 최저순위] 반복문, 조건문의 단순 활용 (0) | 2021.06.10 |
[프로그래머스 level1 신규 아이디 추천] 조건을 하나씩 차근차근 사용하기 (0) | 2021.06.10 |
Comments