늘 겸손하게

문제 11047 ( C++ ) 본문

코딩 문제/백준

문제 11047 ( C++ )

besforyou999 2021. 7. 2. 22:29

그리디 알고리즘 문제

 

가장 큰 숫자부터 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*)mallocsizeof(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