일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 백준
- Level2
- AWS
- 우아한세미나
- 세션
- 서블릿
- 스프링부트
- MSA
- mock
- 코드리뷰
- 트랜잭션
- 자바
- 우아한테크코스
- 우테코
- 프로그래머스
- 스프링 부트
- 레벨2
- 미션
- JUnit5
- REDIS
- 프리코스
- yml
- AOP
- Spring Batch
- CircuitBreaker
- JPA
- 의존성
- Paging
- Docker
- HTTP
Archives
- Today
- Total
늘
acmicpc_1699(제곱수의 합) 본문
728x90
#include <iostream>
#include <algorithm>
using namespace std;
int i, n;
int d[100001];
int main() {
cin >> n;
for (i = 0; i <= n; i++)
d[i] = i;
for (i = 2; i <= n; i++) {
for (int j = 2; j * j <= i; ++j) {
d[i] = min(d[i], d[i - j * j] + 1);
}
}
cout << d[n];
return 0;
}
너무 오랜만이네요..ㅎㅎ 스프링 부트가 재밌어서 공부하다 보니 알고리즘에 소홀하게 됐네욤..^^
이번 문제는 예전에 틀려서 도저히 모르겠어서 방치해뒀던 문제인데 이번 기회에 풀어보았답니다!(힌트 슬쩍 얻긴했음)
dp문제인데 생각보다 간단하게 제곱수 만큼 빼보면서 비교하면 되었던 문제!
728x90
Comments