
방법1. Scanner
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int N = sc.nextInt(), K = sc.nextInt();
int []coin = new int[N];
int count = 0;
for (int i = 0; i < N; i++) {
coin[i] = sc.nextInt();
}
for (int i = N-1; i >= 0; i--) {
if(K >= coin[i]) {
count += (K / coin[i]);
K = (K % coin[i]);
}
}
System.out.println(count);
}
}
처리 속도가 느린 단점이 있다.
방법2. BufferedReader
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.StringTokenizer;
public class Mains {
public static void main(String[] args) throws IOException{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
int N = Integer.parseInt(st.nextToken());
int K = Integer.parseInt(st.nextToken());
int[] coin = new int [N];
for (int i = 0; i < N; i++) {
coin[i] = Integer.parseInt(br.readLine());
}
int count = 0;
for (int i = N-1; i >= 0; i--) {
if(K >= coin[i]) {
count += K / coin[i];
K = K % coin[i];
}
}
bw.write(String.valueOf(count));
br.close();
bw.close();
}
}
속도에서 월등히 빠른것을 확인 할 수 있다.