일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- Database
- react
- Graph
- Data Structure
- vscode
- 프로그래머스
- Python
- TypeScript
- VIM
- 동적 계획법
- CS
- java
- 그레이들
- 안드로이드
- Javascript
- DFS
- DP
- db
- network
- 자바
- 리트코드
- 다이나믹 프로그래밍
- BFS
- frontend
- LeetCode
- git
- 알고리즘
- 백준
- Redux
- Algorithm
Archives
- Today
- Total
늘 겸손하게
문제 11047 ( C++ ) 본문
그리디 알고리즘 문제
가장 큰 숫자부터 K를 나누고 그 몫을 계속 누적하여 더하면서 그 나머지를 K에 다시 저장하는것을 K가 0이 될때까지 반복하면 풀리는 문제
코드
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
32
33
|
#include <iostream>
using namespace std;
int main(void) {
int N , K;
cin >> N >> K;
int * arr = (int*)malloc( sizeof(int) * N );
for (int i = 0 ; i < N ; i++ ) {
cin >> arr[i];
}
int count = 0;
while ( K != 0 ) {
count += K / arr[N-1] ;
K = K % arr[N-1];
N--;
}
cout << count;
free(arr);
arr = NULL;
return 0;
}
|
cs |
N을 입력받아 동적으로 배열을 생성한 후 제공하는 N개의 Ai를 받는다.
그리고 제일 큰 Ai부터 K를 나누고 그 몫을 count에 더해준다.
K를 Ai로 나눈 나머지를 다시 K 에 저장하여 위의 과정을 K가 0이 될때까지 반복한다.
마지막으로 count를 출력하고 동적 할당한 배열을 해제해준다.
사진에 컴파일 에러는 자바로 구현했다가 난 에러입니다. 왜 에러나는지는 잘 모르겠네요 버전 문제인가
'코딩 문제 > 백준' 카테고리의 다른 글
문제 11399 ( Java ) - ATM 문제 (0) | 2021.07.04 |
---|---|
문제 1931 ( C++) (0) | 2021.07.03 |
문제 15649 ( C++ ) (0) | 2021.06.29 |
문제 2798 ( C++ ) (0) | 2021.06.29 |
문제 10870 ( C++ / Python ) (0) | 2021.06.29 |