시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 (추가 시간 없음) 512 MB52332356.098%

문제

Albert는 최근 재미있는 문제를 풀고 있다. 길이 n+1인 배열 A가 1부터 n-1까지의 정수를 한 번씩 포함하고, n을 두 번 포함하면 배열 A는 좋은 배열이다. 길이가 n+1인 좋은 배열의 개수는 정확히 (n+1)!/2 개 존재한다.

A가 길이 n+1인 좋은 배열이라면, Score(A) 는 다음과 같이 정의 된다: 1 ≤ i < j ≤ n+1 과 A[i] < A[j] 를 만족하는 쌍 (i, j)의 개수. 만약 A = [1, 2, 3, ..., n-1, n, n] 이라면 Score(A)는 (n+2)(n-1)/2로 최대가 되며, A = [n, n, n-1, n-2, ..., 2, 1] 이라면 Score(A) = 0으로 최소가 된다.

Albert는 n과 두 개의 정수 a, b 가 주어졌을 때, a ≤ Score(A) ≤ b 를 만족하는 길이 n+1인 좋은 배열의 개수를 세는 문제를 풀고 싶다. 예를 들어, n = 3, a = 2, b = 3 이라 하자. 총 12개의 좋은 배열 중 a ≤ Score(A) ≤ b를 만족하는 길이 4인 좋은 배열의 개수는 6개이다.

  • A = [1, 2, 3, 3]: Score(A) = 5
  • A = [1, 3, 2, 3]: Score(A) = 4
  • A = [1, 3, 3, 2]: Score(A) = 3 (만족)
  • A = [2, 1, 3, 3]: Score(A) = 4
  • A = [2, 3, 1, 3]: Score(A) = 3 (만족)
  • A = [2, 3, 3, 1]: Score(A) = 2 (만족)
  • A = [3, 1, 2, 3]: Score(A) = 3 (만족)
  • A = [3, 1, 3, 2]: Score(A) = 2 (만족)
  • A = [3, 2, 1, 3]: Score(A) = 2 (만족)
  • A = [3, 2, 3, 1]: Score(A) = 1
  • A = [3, 3, 1, 2]: Score(A) = 1
  • A = [3, 3, 2, 1]: Score(A) = 0

입력으로 n, a, b 가 주어졌을 때, a ≤ Score(A) ≤ b 를 만족하는 길이 n+1인 좋은 배열 A의 개수를 출력하는 프로그램을 작성하시오.

입력

첫 줄에 테스트 케이스의 수 T가 주어진다.

각 테스트 케이스는 한 줄에 n, a, b 가 공백으로 구분되어 주어진다.

출력

각 테스트 케이스의 정답을 한 줄에 출력한다.

단, 답이 매우 클 수 있으므로 정답을 109+7 (= 1,000,000,007) 로 나눈 값을 출력한다.

제한

  • 1 ≤ T ≤ 10,000
  • 2 ≤ n ≤ 1,000
  • 0 ≤ a ≤ b ≤ 1,000

예제 입력 1

5
3 2 3
4 0 1
4 4 5
8 10 20
12 0 77

예제 출력 1

6
4
22
123924
113510379

케이스 1: 본문에서 다루었다.

케이스 2: 다음 4개의 배열이 조건을 만족한다: [4, 4, 3, 2, 1], [4, 4, 3, 1, 2], [4, 4, 2, 3, 1], [4, 3, 4, 2, 1]

케이스 3: 추가 설명 없음

케이스 4: 추가 설명 없음

케이스 5: 모든 길이 13인 좋은 배열이 조건을 만족하므로 답은 3113510400 이지만 10^9+7로 나눈 나머지는 113510379 이다.

[{"problem_id":"20918","problem_lang":"0","title":"\uc88b\uc740 \ubc30\uc5f4 \uc138\uae30","description":"<p>Albert\ub294 \ucd5c\uadfc \uc7ac\ubbf8\uc788\ub294 \ubb38\uc81c\ub97c \ud480\uace0 \uc788\ub2e4. \uae38\uc774 n+1\uc778&nbsp;\ubc30\uc5f4 A\uac00 1\ubd80\ud130 n-1\uae4c\uc9c0\uc758 \uc815\uc218\ub97c \ud55c \ubc88\uc529 \ud3ec\ud568\ud558\uace0, n\uc744 \ub450 \ubc88 \ud3ec\ud568\ud558\uba74 \ubc30\uc5f4 A\ub294 <strong>\uc88b\uc740 \ubc30\uc5f4<\/strong>\uc774\ub2e4. \uae38\uc774\uac00 n+1\uc778&nbsp;\uc88b\uc740 \ubc30\uc5f4\uc758 \uac1c\uc218\ub294 \uc815\ud655\ud788 (n+1)!\/2 \uac1c \uc874\uc7ac\ud55c\ub2e4.<\/p>\r\n\r\n<p>A\uac00 \uae38\uc774 n+1\uc778 \uc88b\uc740 \ubc30\uc5f4\uc774\ub77c\uba74, Score(A) \ub294 \ub2e4\uc74c\uacfc \uac19\uc774 \uc815\uc758 \ub41c\ub2e4: 1 &le; i &lt; j &le; n+1 \uacfc A[i] &lt; A[j] \ub97c \ub9cc\uc871\ud558\ub294 \uc30d (i, j)\uc758 \uac1c\uc218. \ub9cc\uc57d A = [1, 2, 3, ..., n-1, n, n] \uc774\ub77c\uba74 Score(A)\ub294 (n+2)(n-1)\/2\ub85c \ucd5c\ub300\uac00 \ub418\uba70, A = [n, n, n-1, n-2, ..., 2, 1] \uc774\ub77c\uba74 Score(A) = 0\uc73c\ub85c \ucd5c\uc18c\uac00 \ub41c\ub2e4.<\/p>\r\n\r\n<p>Albert\ub294 n\uacfc \ub450 \uac1c\uc758 \uc815\uc218 a, b \uac00 \uc8fc\uc5b4\uc84c\uc744 \ub54c, a &le; Score(A) &le; b \ub97c \ub9cc\uc871\ud558\ub294 \uae38\uc774 n+1\uc778 \uc88b\uc740 \ubc30\uc5f4\uc758 \uac1c\uc218\ub97c \uc138\ub294 \ubb38\uc81c\ub97c \ud480\uace0 \uc2f6\ub2e4. \uc608\ub97c \ub4e4\uc5b4, n = 3, a = 2, b = 3&nbsp;\uc774\ub77c \ud558\uc790. \ucd1d 12\uac1c\uc758 \uc88b\uc740 \ubc30\uc5f4 \uc911 a &le; Score(A) &le; b\ub97c \ub9cc\uc871\ud558\ub294 \uae38\uc774 4\uc778 \uc88b\uc740 \ubc30\uc5f4\uc758 \uac1c\uc218\ub294 6\uac1c\uc774\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>A = [1, 2, 3, 3]: Score(A) = 5<\/li>\r\n\t<li>A = [1, 3, 2, 3]: Score(A) = 4<\/li>\r\n\t<li>A = [1, 3, 3, 2]: Score(A) = 3 (\ub9cc\uc871)<\/li>\r\n\t<li>A = [2, 1, 3, 3]: Score(A) = 4<\/li>\r\n\t<li>A = [2, 3, 1, 3]: Score(A) = 3 (\ub9cc\uc871)<\/li>\r\n\t<li>A = [2, 3, 3, 1]: Score(A) = 2 (\ub9cc\uc871)<\/li>\r\n\t<li>A = [3, 1, 2, 3]: Score(A) = 3 (\ub9cc\uc871)<\/li>\r\n\t<li>A = [3, 1, 3, 2]: Score(A) = 2 (\ub9cc\uc871)<\/li>\r\n\t<li>A = [3, 2, 1, 3]: Score(A) = 2 (\ub9cc\uc871)<\/li>\r\n\t<li>A = [3, 2, 3, 1]: Score(A) = 1<\/li>\r\n\t<li>A = [3, 3, 1, 2]: Score(A) = 1<\/li>\r\n\t<li>A = [3, 3, 2, 1]: Score(A) = 0<\/li>\r\n<\/ul>\r\n\r\n<p>\uc785\ub825\uc73c\ub85c n, a, b \uac00 \uc8fc\uc5b4\uc84c\uc744 \ub54c, a &le; Score(A) &le; b \ub97c \ub9cc\uc871\ud558\ub294 \uae38\uc774 n+1\uc778 \uc88b\uc740 \ubc30\uc5f4 A\uc758 \uac1c\uc218\ub97c \ucd9c\ub825\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\uc2dc\uc624.<\/p>\r\n","input":"<p>\uccab \uc904\uc5d0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc218 T\uac00 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 \ud55c \uc904\uc5d0 n, a, b \uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758&nbsp;\uc815\ub2f5\uc744 \ud55c \uc904\uc5d0 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n\r\n<p>\ub2e8, \ub2f5\uc774 \ub9e4\uc6b0 \ud074 \uc218 \uc788\uc73c\ubbc0\ub85c \uc815\ub2f5\uc744 10<sup>9<\/sup>+7 (= 1,000,000,007) \ub85c \ub098\ub208 \uac12\uc744 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>1 &le; T &le; 10,000<\/li>\r\n\t<li>2 &le; n &le; 1,000<\/li>\r\n\t<li>0 &le; a &le; b &le; 1,000<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>\ucf00\uc774\uc2a4 1: \ubcf8\ubb38\uc5d0\uc11c \ub2e4\ub8e8\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\ucf00\uc774\uc2a4 2: \ub2e4\uc74c 4\uac1c\uc758 \ubc30\uc5f4\uc774 \uc870\uac74\uc744 \ub9cc\uc871\ud55c\ub2e4: [4, 4, 3, 2, 1], [4, 4, 3, 1, 2], [4, 4, 2, 3, 1], [4, 3, 4, 2, 1]<\/p>\r\n\r\n<p>\ucf00\uc774\uc2a4 3: \ucd94\uac00 \uc124\uba85 \uc5c6\uc74c<\/p>\r\n\r\n<p>\ucf00\uc774\uc2a4 4: \ucd94\uac00 \uc124\uba85 \uc5c6\uc74c<\/p>\r\n\r\n<p>\ucf00\uc774\uc2a4 5: \ubaa8\ub4e0 \uae38\uc774 13\uc778 \uc88b\uc740 \ubc30\uc5f4\uc774&nbsp;\uc870\uac74\uc744 \ub9cc\uc871\ud558\ubbc0\ub85c \ub2f5\uc740&nbsp;3113510400 \uc774\uc9c0\ub9cc 10^9+7\ub85c \ub098\ub208 \ub098\uba38\uc9c0\ub294&nbsp;113510379 \uc774\ub2e4.<\/p>\r\n"},{"problem_id":"20918","problem_lang":"1","title":"Good Arrays","description":"<p>Albert is working on a fun problem. If an array A contains n+1 numbers such that it contains each integer from 1 to n-1 exactly once and it contains n twice, then A is a <strong>good array<\/strong>. There are exactly (n+1)!\/2 good arrays of length n+1.<\/p>\r\n\r\n<p>If A is a good array of length n+1, Score(A) is defined as follows:&nbsp;The number of pairs (i, j) where 1 &le; i &lt; j &le; n+1&nbsp;and A[i] &lt; A[j]. If&nbsp;A = [1, 2, 3, ..., n-1, n, n], then&nbsp;Score(A) =&nbsp;(n+2)(n-1)\/2 (which is maximum) and if&nbsp;A = [n, n, n-1, n-2, ..., 2, 1], then Score(A) = 0 (which is minimum).<\/p>\r\n\r\n<p>Given n and two integers a and b, Albert wants to count the number of good arrays A of length n+1 such that a &le; Score(A) &le; b. For instance, suppose that&nbsp;n = 3, a = 2, and b = 3. Out of 12 good arrays of length n+1, there exist 6 good arrays such that&nbsp;a &le; Score(A) &le;&nbsp;b.<\/p>\r\n\r\n<ul>\r\n\t<li>A = [1, 2, 3, 3]: Score(A) = 5<\/li>\r\n\t<li>A = [1, 3, 2, 3]: Score(A) = 4<\/li>\r\n\t<li>A = [1, 3, 3, 2]: Score(A) = 3 (OK)<\/li>\r\n\t<li>A = [2, 1, 3, 3]: Score(A) = 4<\/li>\r\n\t<li>A = [2, 3, 1, 3]: Score(A) = 3 (OK)<\/li>\r\n\t<li>A = [2, 3, 3, 1]: Score(A) = 2 (OK)<\/li>\r\n\t<li>A = [3, 1, 2, 3]: Score(A) = 3 (OK)<\/li>\r\n\t<li>A = [3, 1, 3, 2]: Score(A) = 2 (OK)<\/li>\r\n\t<li>A = [3, 2, 1, 3]: Score(A) = 2 (OK)<\/li>\r\n\t<li>A = [3, 2, 3, 1]: Score(A) = 1<\/li>\r\n\t<li>A = [3, 3, 1, 2]: Score(A) = 1<\/li>\r\n\t<li>A = [3, 3, 2, 1]: Score(A) = 0<\/li>\r\n<\/ul>\r\n\r\n<p>Given n, a, and b, compute the number of good arrays A of length n+1 such that&nbsp;a &le; Score(A) &le; b is satisfied.<\/p>\r\n","input":"<p>The first line will contain the number of test cases, T.<\/p>\r\n\r\n<p>Each test case will be described in a single line that will contain n, a, and b, separated by a whitespace.<\/p>\r\n","output":"<p>For each test case, output the answer in a single line.<\/p>\r\n\r\n<p>Since the answer can be very large, output the answer modulo&nbsp;10<sup>9<\/sup>+7 (= 1,000,000,007).<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>1 &le; T &le; 10,000<\/li>\r\n\t<li>2 &le; n &le; 1,000<\/li>\r\n\t<li>0 &le; a &le; b &le; 1,000<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>Case 1: Explained in the problem statement.<\/p>\r\n\r\n<p>Case 2: These four arrays meet the requirements: [4, 4, 3, 2, 1], [4, 4, 3, 1, 2], [4, 4, 2, 3, 1], [4, 3, 4, 2, 1]<\/p>\r\n\r\n<p>Case 3: No explanation is provided.<\/p>\r\n\r\n<p>Case 4: No explanation is provided.<\/p>\r\n\r\n<p>Case 5: All good arrays of length 13 satisfy the requirements, so the answer is&nbsp;3113510400. However, you must output the answer modulo 10^9+7, which is 113510379.<\/p>\r\n"}]