일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 페이코 추천인코드
- php 프로그래밍 입문 예제
- JAVA SPRING
- 파이썬
- php
- php 프로그래밍 입문
- 플러터 개발환경 설정
- 백준
- 스프링
- Flutter
- php 프로그래밍 입문 문제풀이
- SWEA
- 배열
- php 프로그래밍 입문 3판
- 플러터
- C
- 자바 스프링
- 자바
- 페이코 초대코드
- Java
- php 프로그래밍 입문 연습문제
- 최단 경로
- php 프로그래밍
- spring
- C언어
- php 프로그래밍 입문 솔루션
- 페이코 추천인
- programmers
- 페이코 친구코드
- 한정 분기
Archives
- Today
- Total
01-26 00:09
ImJay
[BOJ/Java] 17626. Four Squares 본문
반응형
[BOJ/Java] 17626. Four Squares
문제 해석
이 문제는 주어진 수 𝑁을 최소 개수의 제곱수 합으로 표현할 때 필요한 제곱수의 개수를 찾는 문제이다. 예를 들어, 𝑁=13이면 2^2+3^2=13이므로, 최소 개수는 2개이다.
풀이 과정
- 다이나믹 프로그래밍(DP) 사용: 문제를 해결하기 위해 다이나믹 프로그래밍 기법을 적용한다.
- DP 배열 초기화: dp[i]는 숫자 𝑖를 제곱수의 합으로 나타낼 때 필요한 최소 제곱수의 개수이다.
- 점화식 계산: 각 숫자 𝑖에 대하여 가능한 모든 제곱수 𝑗^2를 사용하여, 𝑑𝑝[𝑖−𝑗^2]를 참조하며 𝑑𝑝[𝑖]의 값을 갱신한다.
코드
package edu.ssafy.im.BOJ.Silver.S3.No17626;
import java.io.*;
public class Main {
private static int N; // 주어진 수 N
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringBuilder sb = new StringBuilder();
N = Integer.parseInt(br.readLine()); // 입력 받은 N
int[] dp = new int[N + 1]; // DP 배열
dp[1] = 1; // 초기값 설정
int min;
for (int i = 1; i <= N; i++) {
min = Integer.MAX_VALUE;
for (int j = 1; j * j <= i; j++) { // 모든 j에 대하여 j^2이 i 이하일 때
int k = i - j * j;
min = Math.min(min, dp[k]); // 최소값 갱신
}
dp[i] = min + 1; // 최소 제곱수의 개수 갱신
}
sb.append(dp[N]); // 결과 출력
bw.write(sb.toString());
bw.flush();
bw.close();
}
}
시간 복잡도 분석
각 숫자 𝑖에 대하여, 가능한 𝑗의 개수는 최대 𝑖개이므로, 이 알고리즘의 시간 복잡도는 𝑂(𝑁root(𝑁))이다.
느낀점
Four Squares 문제는 수학적으로 중요한 문제 유형 중 하나로, 다이나믹 프로그래밍을 이용해 최적화 문제를 해결하는 기본적인 접근법을 보여준다. 이 문제를 통해 제곱수의 합으로 수를 표현하는 문제를 효율적으로 해결하는 방법을 배울 수 있었다. 이러한 문제는 컴퓨터 과학뿐만 아니라 순수 수학에서도 연구되는 중요한 주제이다.
반응형
'알고리즘 > BOJ - Java' 카테고리의 다른 글
[BOJ/Java] 20529. 가장 가까운 세 사람의 심리적 거리 (0) | 2024.04.22 |
---|---|
[BOJ/Java] 21736. 헌내기는 친구가 필요해 (0) | 2024.04.22 |
[BOJ/Java] 17471. 게리맨더링 (0) | 2024.04.22 |
[BOJ/Java] 17219. 비밀번호 찾기 (0) | 2024.04.22 |
[BOJ/Java] 17136. 색종이 붙이기 (0) | 2024.04.22 |
Comments