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
- backend
- nGrinder
- java
- F-Lab
- FLAB
- 알고리즘
- 성능테스트
- MySQL
- IntelliJ
- 에프랩
- 코딩테스트
- Flutter
- github
- 데이터구조
- 부트캠프
- error
- grafana
- 자바백엔드
- 후기
- AWS
- 자바
- 도커
- 로드밸런서
- Spring
- EC2
- 멘토링
- 플러터
- 트러블슈팅
- 레디스
- 백엔드
Archives
- Today
- Total
민스씨의 일취일장
h.o. Algorithm | Java | 백준 1789 - 구현 & 그리디 - 무의미한 로직은 생략 본문
반응형
백준 1789 풀이 알고리즘을 분석하는 글이다.
h.o. Algorithm | Java | 백준 1789 - 구현 & 그리디 - 무의미한 로직은 생략
문제
서로 다른 N개의 자연수의 합이 S라고 한다. S를 알 때, 자연수 N의 최댓값은 얼마일까?
문제 분석
- N개의 자연수의 합이 S이다.
- N의 최댓값, 즉 최대한 많은 수를 더해 S를 구해야 한다.
- 많은 수를 더하기 위해선 1부터 사용할 수 있는 작은 자연수를 모두 더해야 한다.
알고리즘
import java.io.*;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
long S = Long.parseLong(br.readLine());
long sum = 0;
int N = 0;
for(int i=1; ; i++){
if(sum + i > S){
break;
}
sum += i;
N++;
}
System.out.println(N);
}
}
알고리즘 분석
- S가 넘지 않은 최대 자연수까지 구한 후 해당 N을 출력한다.
질문 : S가 넘지 않을 때까지만 더했는데, 문제에서는 자연수의 합이 S이 되는 자연수의 수를 구하라고 했다. 문제 조건을 충족시키지 않는다.
- S가 넘지 않은 최대 자연수 N까지의 값을 더하고, N+1을 더한다. 그럼 S보다 큰 수가 된다. (현재 N+1)
- S보다 큰 수에서, S를 뺀 수를 하나 뺀다고 생각하자. 그럼 N+1개에서 한 개를 뺐으므로 자연수의 수는 다시 N이 된다. (현재 N)
하지만 실제 코드 작성시에는 마지막 두 단계를 생략했다. 알고리즘 이면에 수학적 해석이 들어가 있다. 이를 통해 로직은 존재하지만, 무의미한 작업 코드는 생략된 알고리즘이 작성됐다.
728x90
반응형