시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 512 MB0000.000%

문제

В лаборатории искусственного интеллекта разработали новый метод машинного обучения. В процессе обучения программы используется n итераций. Каждая итерация заключается в том, что обучаемая программа запускается на некотором обучающем наборе.

Были подготовлены обучающие наборы сложности от 0 до k. План обучения задаётся массивом целых чисел [a1, a2, . . . , an], где ai задаёт сложность набора, используемого на i-й итерации обучения. Для всех i от 1 до n должно выполняться неравенство 0 ⩽ ai ⩽ k.

Выяснилось, что эффективность плана обучения зависит от битовых представлений сложностей обучающих наборов. Для того, чтобы план был эффективным, необходимо, чтобы для любых двух значений i и j, где 1 ⩽ i < j ⩽ n, выполнялось (ai and aj) = ai. Напомним, что побитовое «и» (and) двух целых неотрицательных чисел устроено следующим образом: запишем оба числа в двоичной системе счисления, i-й двоичный разряд результата равен 1, если у обоих аргументов он равен 1. Например, (14 and 7) = (11102 and 01112) = 1102 = 6. Эта операция реализована во всех современных языках программирования, в языках C++, Java и Python она записывается как «&», в Паскале как «and».

Однако постоянное использование наборов одной сложности не даёт прогресса в обучении. Чтобы этого избежать, для плана обучения должны быть выполнены m требований следующего вида. Каждое требование задаётся двумя числами li и ri и означает, что ali ≠ ari.

Сотрудники лаборатории хотят найти количество эффективных планов, которые удовлетворяют всем требованиям. Так как это число может быть очень большим, нужно найти его остаток от деления на 109 + 7.

Требуется написать программу, которая по заданным целым числам n и k, а также m требованиям вида li, ri определяет количество эффективных планов, которые удовлетворяют всем требованиям, и выводит остаток от деления этого количества на число 109 + 7.

입력

Первая строка входных данных содержит три целых числа n, m и k — количество итераций обучения, количество требований и максимальную сложность обучающего набора (1 ⩽ n ⩽ 3 · 105, 0 ⩽ m ⩽ 3 · 105, 0 ⩽ k ⩽ 1018).

Следующие m строк описывают требования, i-я строка содержит два целых числа li, ri, которые означают, что ali ≠ ari (1 ⩽ li < ri ⩽ n). Гарантируется, что все требования различны.

출력

Выведите одно целое число — остаток от деления количества эффективных планов, удовлетворяющих всем требованям, на число 109 + 7.

서브태스크

번호배점제한
18

1 ⩽ n ⩽ 500

m = 0

0 ⩽ k ⩽ 500

220

1 ⩽ n ⩽ 3 · 105

m = 0

0 ⩽ k ⩽ 107

310

1 ⩽ n ⩽ 3 · 105

m = 0

0 ⩽ k ⩽ 1018

48

1 ⩽ n ⩽ 50

0 ⩽ m ⩽ 50

0 ⩽ k ⩽ 50

516

1 ⩽ n ⩽ 2000

0 ⩽ m ⩽ 2000

0 ⩽ k ⩽ 107

66

1 ⩽ n ⩽ 2000

0 ⩽ m ⩽ 2000

0 ⩽ k ⩽ 1018

710

1 ⩽ n ⩽ 3 · 105

0 ⩽ m ⩽ 200

0 ⩽ k ⩽ 107

86

1 ⩽ n ⩽ 3 · 105

0 ⩽ m ⩽ 200

0 ⩽ k ⩽ 1018

916

1 ⩽ n ⩽ 3 · 105

0 ⩽ m ⩽ 3 · 105

0 ⩽ k ⩽ 1018

예제 입력 1

2 0 3

예제 출력 1

9

예제 입력 2

3 1 2
1 2

예제 출력 2

2

힌트

Все возможные планы для первого теста: [0, 0], [0, 1], [0, 2], [0, 3], [1, 1], [1, 3], [2, 2], [2, 3], [3, 3]. Для второго теста: [0, 1, 1], [0, 2, 2].

채점 및 기타 정보

  • 예제는 채점하지 않는다.