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
- with recursive
- 웹어플리케이션 서버
- 백준 16719
- 프로래머스
- Spring Boot
- MSA
- springboot
- JPA
- Kotlin
- java 기술면접
- spring security
- sql 기술면접
- 백준 15685
- 백준
- 파이썬
- 백준 17626
- spring cloud
- Spring
- 백준 19238
- JVM
- 백준 16236
- Coroutine
- 백준 17779
- 백준 16235
- spring oauth
- re.split
- java
- 백준 파이썬
- MySQL
- 프로그래머스
Archives
- Today
- Total
시작이 반
[백준] 17626번 (python 파이썬) 본문
SMALL
DP 또는 완탐으로 풀수 있다.
완탐으로 문제를 해결하였다.
해당 숫자의 int(제곱근)부터 해당 숫자 - int(제곱근)^2 의 제곱근-1까지 반복문을 돌려서 확인하였다.
사실 그냥 해당 숫자의 int(제곱근)부터 0까지 돌려도 풀린다.
import math
n = int(input())
answer = 4
def solve():
global answer, n
sqrt = int(math.sqrt(n))
for i in range(sqrt, int(math.sqrt(n - sqrt ** 2)) - 1, -1):
n -= i ** 2
if n == 0:
answer = min(1, answer)
sqrt2 = int(math.sqrt(n))
for j in range(sqrt2, int(math.sqrt(n - sqrt2 ** 2)) - 1, -1):
n -= j ** 2
if n == 0:
answer = min(2, answer)
sqrt3 = int(math.sqrt(n))
for k in range(sqrt3, int(math.sqrt(n - sqrt3 ** 2)) - 1, -1):
n -= k ** 2
if n == 0:
answer = min(3, answer)
elif n == 1:
answer = min(4, answer)
n += k ** 2
n += j ** 2
n += i ** 2
solve()
print(answer)
범위를 0까지 했을때
import math
n = int(input())
answer = 4
def solve():
global answer, n
sqrt = int(math.sqrt(n))
for i in range(sqrt, 0, -1):
n -= i ** 2
if n == 0:
answer = min(1, answer)
sqrt2 = int(math.sqrt(n))
for j in range(sqrt2, 0, -1):
n -= j ** 2
if n == 0:
answer = min(2, answer)
sqrt3 = int(math.sqrt(n))
for k in range(sqrt3, 0, -1):
n -= k ** 2
if n == 0:
answer = min(3, answer)
elif n == 1:
answer = min(4, answer)
n += k ** 2
n += j ** 2
n += i ** 2
solve()
print(answer)
LIST
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 19238번 (python 파이썬) (0) | 2021.04.19 |
---|---|
[백준] 17779번 (python 파이썬) (0) | 2021.04.19 |
[백준] 13549번 (python 파이썬) (0) | 2021.04.17 |
[백준] 17140번 (python 파이썬) (0) | 2021.04.17 |
[백준] 17135번 (python 파이썬) (0) | 2021.04.16 |