Submission details
Task:Jubilee
Sender:solosolve
Submission time:2025-11-08 14:20:39 +0200
Language:C++ (C++20)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.02 sdetails
#7ACCEPTED0.00 sdetails
#8ACCEPTED0.00 sdetails
#9ACCEPTED0.00 sdetails
#10ACCEPTED0.01 sdetails
#11ACCEPTED0.02 sdetails
#12ACCEPTED0.00 sdetails
#13ACCEPTED0.00 sdetails
#14ACCEPTED0.01 sdetails

Code

#include <bits/stdc++.h>

using namespace std;

using ll = long long;

const ll MOD   = 1e9 + 7;

int main()
{
    ios_base::sync_with_stdio(false);

    ll n, m;
    cin >> n >> m;

    if (m == 1)
    {
        cout << 0 << '\n';
        return 0;
    }

    ll answer = m * (m - 1) % MOD;
    for (ll i = 1; i < n; i++)
    {
        ll first = 0;
        first = (answer * (m - 1)) % MOD;
        ll second = 0;
        if (m >= 3)
            second = (answer * (((m - 2) * (m - 2)) % MOD)) % MOD;
        answer = (first + second) % MOD;
    }
    cout << answer << '\n';

    return 0;
}

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