Submission details
Task:Jubilee
Sender:Very Competitive Programmers
Submission time:2025-11-08 16:35:12 +0200
Language:Python3 (PyPy3)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.04 sdetails
#2ACCEPTED0.04 sdetails
#3ACCEPTED0.04 sdetails
#4ACCEPTED0.04 sdetails
#5ACCEPTED0.04 sdetails
#6ACCEPTED0.04 sdetails
#7ACCEPTED0.04 sdetails
#8ACCEPTED0.04 sdetails
#9ACCEPTED0.04 sdetails
#10ACCEPTED0.04 sdetails
#11ACCEPTED0.04 sdetails
#12ACCEPTED0.04 sdetails
#13ACCEPTED0.04 sdetails
#14ACCEPTED0.04 sdetails

Code

import sys
sys.setrecursionlimit(1_000_000_000)

n, m = input().split()
n = int(n)
m = int(m)

M = 1000000000 + 7

def modpow(n,m):
    # n**m = (n**(m/2)) ** 2
    if m == 0:
        return 1
    if m % 2 == 1:
        return n*modpow(n,m-1) % M
    k = modpow(n,m//2) % M
    return k*k % M

print((m * (m-1) * modpow((m-2)*(m-2) + m-1,n-1)) % M)

Test details

Test 1

Verdict: ACCEPTED

input
3 2

correct output
2

user output
2

Test 2

Verdict: ACCEPTED

input
1 1

correct output
0

user output
0

Test 3

Verdict: ACCEPTED

input
1 1000000000

correct output
56

user output
56

Test 4

Verdict: ACCEPTED

input
2 1000000000

correct output
4088

user output
4088

Test 5

Verdict: ACCEPTED

input
3 1000000000

correct output
298424

user output
298424

Test 6

Verdict: ACCEPTED

input
1000000 1000000000

correct output
859388820

user output
859388820

Test 7

Verdict: ACCEPTED

input
2 1

correct output
0

user output
0

Test 8

Verdict: ACCEPTED

input
1000000 1

correct output
0

user output
0

Test 9

Verdict: ACCEPTED

input
1 2

correct output
2

user output
2

Test 10

Verdict: ACCEPTED

input
1000000 2

correct output
2

user output
2

Test 11

Verdict: ACCEPTED

input
1000000 3

correct output
129870828

user output
129870828

Test 12

Verdict: ACCEPTED

input
1 3

correct output
6

user output
6

Test 13

Verdict: ACCEPTED

input
21355 1239478

correct output
74219157

user output
74219157

Test 14

Verdict: ACCEPTED

input
531578 913517291

correct output
105420893

user output
105420893