그리디 알고리즘은 현재 상태에서 선택할 수 있는 선택 중 최선의 선택지가 전체 선택지 중 최선의 선택지라고 가정하는 알고리즘이다.
import java.util.*;
class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int k = sc.nextInt();
int[] a = new int[n];
for (int i = 0; i < n; i++) {
a[i] = sc.nextInt();
}
int count = 0;
for (int i = n - 1; i >= 0; i--) {
if (a[i] <= k) {
count += (k / a[i]);
k = k % a[i];
if (k == 0) break;
}
}
System.out.println(count);
}
}
import java.util.*;
class Main {
public static void main(String[] args) {
int answer = 0;
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
String[] strs = str.split("-");
for (int i = 0; i < strs.length; i++) {
int num = sumNumber(strs[i]);
if (i == 0) answer += num;
else answer -= num;
}
System.out.println(answer);
}
public static int sumNumber(String str) {
int sum = 0;
String[] strs = str.split("[+]");
for (int i = 0; i < strs.length; i++) {
sum += Integer.parseInt(strs[i]);
}
return sum;
}
}