μΉ΄μ§λ Έμμ μ μΌ μΈκΈ° μλ κ²μ λΈλμμ κ·μΉμ μλΉν μ½λ€. μΉ΄λμ ν©μ΄ 21μ λμ§ μλ νλ λ΄μμ, μΉ΄λμ ν©μ μ΅λν ν¬κ² λ§λλ κ²μμ΄λ€. λΈλμμ μΉ΄μ§λ Έλ§λ€ λ€μν κ·μ μ΄ μλ€.
νκ΅ μ΅κ³ μ λΈλμ κ³ μ κΉμ μΈμ μλ‘μ΄ λΈλμ κ·μΉμ λ§λ€μ΄ μκ·Ό, μ°½μμ΄μ κ²μνλ €κ³ νλ€.
κΉμ μΈ λ²μ μ λΈλμμμ κ° μΉ΄λμλ μμ μ μκ° μ°μ¬ μλ€. κ·Έ λ€μ, λλ¬λ Nμ₯μ μΉ΄λλ₯Ό λͺ¨λ μ«μκ° λ³΄μ΄λλ‘ λ°λ₯μ λλλ€. κ·Έλ° νμ λλ¬λ μ«μ Mμ ν¬κ² μΈμΉλ€.
μ΄μ νλ μ΄μ΄λ μ νλ μκ° μμ Nμ₯μ μΉ΄λ μ€μμ 3μ₯μ μΉ΄λλ₯Ό 골λΌμΌ νλ€. λΈλμ λ³ν κ²μμ΄κΈ° λλ¬Έμ, νλ μ΄μ΄κ° κ³ λ₯Έ μΉ΄λμ ν©μ Mμ λμ§ μμΌλ©΄μ Mκ³Ό μ΅λν κ°κΉκ² λ§λ€μ΄μΌ νλ€.
Nμ₯μ μΉ΄λμ μ¨μ Έ μλ μ«μκ° μ£Όμ΄μ‘μ λ, Mμ λμ§ μμΌλ©΄μ Mμ μ΅λν κ°κΉμ΄ μΉ΄λ 3μ₯μ ν©μ κ΅¬ν΄ μΆλ ₯νμμ€.
첫째 μ€μ μΉ΄λμ κ°μ N(3 β€ N β€ 100)κ³Ό M(10 β€ M β€ 300,000)μ΄ μ£Όμ΄μ§λ€. λμ§Έ μ€μλ μΉ΄λμ μ°μ¬ μλ μκ° μ£Όμ΄μ§λ©°, μ΄ κ°μ 100,000μ λμ§ μλ μμ μ μμ΄λ€.
ν©μ΄ Mμ λμ§ μλ μΉ΄λ 3μ₯μ μ°Ύμ μ μλ κ²½μ°λ§ μ
λ ₯μΌλ‘ μ£Όμ΄μ§λ€.
첫째 μ€μ Mμ λμ§ μμΌλ©΄μ Mμ μ΅λν κ°κΉμ΄ μΉ΄λ 3μ₯μ ν©μ μΆλ ₯νλ€.
5 21
5 6 7 8 9
21
β λ°°μ΄μ μλ κ°λ€μ 3κ°μ© λ¬Άμ΄μ ν©μ ꡬνλ€μ κ·Έ ν©λ€ μ€ κ°μ₯ ν° κ°μ΄λ©΄μ 컀νΈλΌμΈλ³΄λ€ μκ±°λ κ°μ κ°μ ꡬνλ€.
#include <iostream>
#define CARD_MAX 100
using namespace std;
int main() {
int card_count = 0, cut_line = 0, max = 0, sum = 0;
int card[CARD_MAX] = { 0, };
cin >> card_count >> cut_line;
for (int i = 0; i < card_count; i++) {
cin >> card[i];
}
for (int i = 0; i < card_count; i++) {
for (int j = i + 1; j < card_count; j++) {
for (int k = j + 1; k < card_count; k++) {
sum = card[i] + card[j] + card[k];
if (sum > max && sum <= cut_line)
max = sum;
}
}
}
cout << max << endl;
return 0;
}