Submission #1130594

#TimeUsernameProblemLanguageResultExecution timeMemory
1130594QuantumPiCarnival (CEOI14_carnival)Java
100 / 100
231 ms18168 KiB
import java.io.*; import java.util.*; public class carnival { public static String[][] queries; public static void main(String[] args) throws IOException { BufferedReader fin = new BufferedReader(new InputStreamReader(System.in)); //BufferedReader fin = new BufferedReader(new FileReader("test.in")); PrintWriter fout = new PrintWriter(System.out); int n = Integer.parseInt(fin.readLine()); queries = new String[n][n]; for (int i=0; i<n; i++) { StringJoiner joiner = new StringJoiner(" "); for (int j=i; j<n; j++) { joiner.add(j+1+""); queries[i][j] = joiner.toString(); } } int[] nums = new int[n]; int currentNum = 1; nums[0] = currentNum++; for (int i=1; i<n; i++) { System.out.println(i+" "+queries[0][i-1]); int a = Integer.parseInt(fin.readLine()); System.out.println(i+1+" "+queries[0][i]); int b = Integer.parseInt(fin.readLine()); if (a < b) { nums[i] = currentNum++; } else { int low = 0; int high = i-1; while (low < high) { int mid = (low+high+1)/2; System.out.println(i-mid+" "+queries[mid][i-1]); int na = Integer.parseInt(fin.readLine()); System.out.println(i+1-mid+" "+queries[mid][i]); int nb = Integer.parseInt(fin.readLine()); if (na == nb) { low = mid; } else { high = mid-1; } } nums[i] = nums[low]; } } StringJoiner joiner = new StringJoiner(" "); joiner.add(0+""); for (int i=0; i<n; i++) { joiner.add(nums[i]+""); } System.out.println(joiner); fin.close(); fout.close(); } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...