제출 #501374

#제출 시각아이디문제언어결과실행 시간메모리
501374churrosKnapsack (NOI18_knapsack)Java
컴파일 에러
0 ms0 KiB
import java.io.*; import java.util.*; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); PrintWriter pw = new PrintWriter(new BufferedWriter(new OutputStreamWriter(System.out))); StringTokenizer st = new StringTokenizer(br.readLine()); int maxWeight = Integer.parseInt(st.nextToken()); int numItemTypes = Integer.parseInt(st.nextToken()); int[] maxVal = new int[maxWeight + 1]; int[] itemValue = new int[numItemTypes]; int[] itemWeight = new int[numItemTypes]; int[] itemCount = new int[numItemTypes]; for (int i = 0; i < numItemTypes; i++) { st = new StringTokenizer(br.readLine()); int value = Integer.parseInt(st.nextToken()); int weight = Integer.parseInt(st.nextToken()); int count = Integer.parseInt(st.nextToken()); itemValue[i] = value; itemWeight[i] = weight; itemCount[i] = count; } for (int i = 0; i < numItemTypes; i++) { int[] timesUsed = new int[maxWeight + 1]; for (int j = 0; j < maxWeight; j++) { int targetWeight = itemWeight[i] + j; if (targetWeight <= maxWeight) { if (maxVal[targetWeight] < maxVal[j] + itemValue[i]) { if (timesUsed[j] < itemCount[i]) { timesUsed[targetWeight] = timesUsed[j] + 1; maxVal[targetWeight] = maxVal[j] + itemValue[i]; } } } } } int ret = 0; for (int i = 0; i <= maxWeight; i++) { ret = Math.max(ret, maxVal[i]); } pw.println(ret); br.close(); pw.close(); } }

컴파일 시 표준 에러 (stderr) 메시지

knapsack.java:4: error: class Main is public, should be declared in a file named Main.java
public class Main {
       ^
1 error