Submission #361438

#TimeUsernameProblemLanguageResultExecution timeMemory
361438AnythingWithJJob Scheduling (CEOI12_jobs)Java
0 / 100
1101 ms39256 KiB
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.util.Arrays; import java.util.PriorityQueue; import java.util.StringTokenizer; public class jobs { // 7 mins planning static int N,D,M; static Integer [] requests; public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); PrintWriter out = new PrintWriter(System.out); StringTokenizer s = new StringTokenizer(br.readLine()); N = Integer.parseInt(s.nextToken()); D = Integer.parseInt(s.nextToken()); M = Integer.parseInt(s.nextToken()); requests = new Integer [M]; s = new StringTokenizer(br.readLine()); for (int i = 0; i < M; i++) { requests[i] = Integer.parseInt(s.nextToken()); } Arrays.sort(requests); int a = 1, b = M; while (a != b) { int mid = (a+b)/2; if (works(mid)) b=mid; else a = mid+1; } out.println(b); out.close(); } static boolean works (int numMachines) { int [] lastDays = new int [numMachines]; int maxD = 0; for (int i = 0, currMach = 0; i < M; i++,currMach++) { int currDay = requests[i]; if (currMach == numMachines) currMach = 0; int nextMachDay = lastDays[currMach]+1; if (nextMachDay > currDay) { maxD = Math.max(maxD,nextMachDay-currDay); lastDays[currMach] = nextMachDay; } else { lastDays[currMach] = currDay; } } return maxD <= D; } }
#Verdict Execution timeMemoryGrader output
Fetching results...