Submission #263619

#TimeUsernameProblemLanguageResultExecution timeMemory
263619ijxjdjdBoat (APIO16_boat)Java
0 / 100
177 ms15272 KiB
import java.io.*; import java.util.ArrayList; import java.util.Collections; import java.util.HashSet; import java.util.StringTokenizer; public class boat { static long[][] choose = new long[501][501]; static long[] inverse = new long[505]; public static long inverse(long a, long mod) { long[] inv = extended_gcd(a, mod); if (inv[0] != 1) { return 0; } else { return (inv[1] + 2*mod)%mod; } } public static long[] extended_gcd(long a, long b) { //three numbers, first is gcd, second is x, third is y if (a == 0) { return new long[]{b, 0, 1}; } long[] next = extended_gcd(b%a, a); long tempX = next[1]; next[1] = next[2] - (b/a) * next[1]; next[2] = tempX; return next; } @SuppressWarnings("unchecked") public static void main(String[] args) { InputReader in = new InputReader(System.in); PrintWriter out = new PrintWriter(System.out); int N = in.nextInt(); int[][] intervals = new int[N][2]; HashSet<Integer> points = new HashSet<>(); for (int i = 0; i <= 500; i++) { choose[i][0] = 1; for (int j = 1; j <= i; j++) { choose[i][j] = (choose[i-1][j] + choose[i-1][j-1])%MOD; } } for (int i = 1; i < inverse.length; i++) { inverse[i] = inverse(i, MOD); } for (int i = 0; i < N; i++) { intervals[i][0] = in.nextInt(); intervals[i][1] = in.nextInt(); points.add(intervals[i][0]); points.add(intervals[i][1]+1); } ArrayList<Integer> pSort = new ArrayList<>(points); ArrayList<Integer>[] items = new ArrayList[pSort.size()]; for (int i = 0; i < pSort.size(); i++) { items[i] = new ArrayList<Integer>(); } Collections.sort(pSort); for (int i = 0; i < N; i++) { boolean flag = false; for (int j = 0; j < pSort.size(); j++) { if (pSort.get(j) == intervals[i][1]+1) { break; } if (flag || pSort.get(j) == intervals[i][0]) { flag = true; items[j].add(i+1); } } } long[] dp = new long[N+1]; dp[0] = 1; for (int i = 0; i < pSort.size()-1; i++) { long[] pref = new long[N+1]; pref[0] = dp[0]; for (int j = 1; j <= N; j++) { pref[j] = dp[j] + pref[j-1]; } long[] pathCount = new long[items[i].size()]; long sz = pSort.get(i+1) - pSort.get(i); long[] szCount = new long[items[i].size()]; szCount[0] = (sz*(sz-1))/2; for (int j = 1; j < items[i].size(); j++) { szCount[j] = szCount[j-1]*(sz - j - 1)*inverse[j+2]; } for (int j = 1; j < items[i].size(); j++) { for (int k = 0; k < j; k++) { pathCount[j] += szCount[k] * choose[j-1][k]; } } pathCount[0] = sz; for (int j = 0; j < items[i].size(); j++) { for (int d = 0; d <= j; d++) { dp[items[i].get(j)] += pathCount[d]*pref[items[i].get(j-d)-1]; } } } long tot = 0; for (int i = 1; i < dp.length; i++) { tot += dp[i]; } out.println(tot); out.close(); } static long MOD = (int)(1e9) + 7; static class InputReader { public BufferedReader reader; public StringTokenizer tokenizer; public InputReader(InputStream stream) { reader = new BufferedReader(new InputStreamReader(stream), 32768); tokenizer = null; } public String next() { while (tokenizer == null || !tokenizer.hasMoreTokens()) { try { tokenizer = new StringTokenizer(reader.readLine()); } catch (IOException e) { throw new RuntimeException(e); } } return tokenizer.nextToken(); } public String nextLine() { try { return reader.readLine(); } catch (IOException e) { throw new RuntimeException(e); } } public int nextInt() { return Integer.parseInt(next()); } public long nextLong() { return Long.parseLong(next()); } } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...