알고리즘/BaekJoon
[c++] 2798번 : 블랙잭
__jhp_+
2022. 4. 28. 14:17
https://www.acmicpc.net/problem/2798
2798번: 블랙잭
첫째 줄에 카드의 개수 N(3 ≤ N ≤ 100)과 M(10 ≤ M ≤ 300,000)이 주어진다. 둘째 줄에는 카드에 쓰여 있는 수가 주어지며, 이 값은 100,000을 넘지 않는 양의 정수이다. 합이 M을 넘지 않는 카드 3장
www.acmicpc.net
#include <iostream>
using namespace std;
int main()
{
ios::sync_with_stdio(false);
cin.tie(NULL);
int n = 0;
int m = 0;
int sum = 0;
int result = 0;
cin >> n >> m;
int* arr = new int[n];
for (int i = 0; i < n; ++i)
{
cin >> arr[i];
}
for (int i = 0; i < n - 2; ++i)
{
for (int j = i + 1; j < n - 1; ++j)
{
for (int k = j + 1; k < n; ++k)
{
sum = arr[i] + arr[j] + arr[k];
if (sum <= m)
{
result = result <= sum ? sum : result;
}
}
}
}
cout << result << '\n';
delete[] arr;
return 0;
}