Challenge: Ajob Subsequence
Subdomeniu: Number Theory (number-theory)
Scor cont: 80.0 / 80
Submission status: Accepted
Submission score: 1.0
Submission ID: 464745985
Limbaj: python3
Link challenge: https://www.hackerrank.com/challenges/ajob-subsequence/problem
Cerinta
You are currently studying the language $Ajob$ ( which means strange in English ) from a renowned professor. The language has infinite number of letters in its alphabet ( now you know, why it is called ajob ).
The professor taught you $N$ words, one by one. The number of letters in a word is equal to it's place in the teaching order. Thus, the $1^{st}$ word taught by the professor has $1$ letter, $2^{nd}$ word has $2$ letters, $3^{rd}$ word has $3$ letters, $\cdots$, the $N^{th}$ word has $N$ letters.
_All the letters within a word are distinct to each other_.
Now, you are handed an assignment. You have to choose any one of the $N$ words and form a subsequence from it. The length of the subsequence should be **exactly** $K$ less than the length of original word. For example, if the length of the chosen word is $L$, then the length of the subsequence should be $L-K$. If for any word, $L$ is smaller than $K$ $(L < K)$, then you must not choose that word. Two subsequences are different to each other if, the lengths of them are different or they contain different characters in the same position.
Find the number of ways you can complete the assignment $\text{modulo } p$ ( $p$ will always be a $prime$ ).
**1.**
The first line contains $T$, the number of testcases. The next $T$ lines contain three space separated integers $N$, $K$ and $p$.
**Output Format**
For each testcase, print one integer in a single line, the number possible ways you can complete the assignment, $\text{modulo } p$.
**Constraints**
$1 \le T \le 100$
$2 \le N \le 10^{18}$
$0 < K < N$
$2 \le p \le 10^5$
$p \text{ is a } Prime$
**Sample Input #00**
3
2 1 2
2 1 5
5 3 13
**Sample Output #00**
1
3
2
**Sample Input #01**
5
5 2 3
6 5 11
7 6 3
6 5 7
6 5 5
**Sample Output #01**
2
7
2
0
2
Cod sursa
# Enter your code here. Read input from STDIN. Print output to STDOUT
import sys
def go():
n, k, p = map(int, sys.stdin.readline().split())
A = n + 1
B = k + 1
res = 1
f = [1]
for i in range(1, p):
f.append(f[-1] * i % p)
while A or B:
a, b = A % p, B % p
A //= p
B //= p
if a < b: return 0
res *= f[a] * pow(f[b] * f[a-b] % p, p - 2, p)
res %= p
return res
for _ in range(int(sys.stdin.readline())):
print(go())
HackerRank Number Theory – Ajob Subsequence
