This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
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 time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |