Submission details
Task:Jubilee
Sender:Hornet's Multithreading
Submission time:2025-11-08 12:42:56 +0200
Language:C++ (C++17)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.01 sdetails
#7ACCEPTED0.00 sdetails
#8ACCEPTED0.00 sdetails
#9ACCEPTED0.00 sdetails
#10ACCEPTED0.01 sdetails
#11ACCEPTED0.01 sdetails
#12ACCEPTED0.00 sdetails
#13ACCEPTED0.00 sdetails
#14ACCEPTED0.01 sdetails

Code

#include <bits/stdc++.h>
using namespace std;

#define rep(i, a, b) for(int i = a; i < (b); i++)
#define all(x) begin(x), end(x)
#define sz(x) (int)(x).size()
typedef long long ll;
typedef pair<int, int> pii;
typedef vector<int> vi;

const int N = 1e6 + 5;
const int MOD = 1e9 + 7;

void add(int &a, int b) {
    a += b;
    if (a >= MOD) {
        a -= MOD;
    }
}

void sub(int &a, int b) {
    a -= b;
    if (a < 0) {
        a += MOD;
    }
}

int mul(int a, int b) {
    return 1LL * a * b % MOD;
}

int n, m;
int f[N];

int main() {
    cin.tie(0)->sync_with_stdio(0);
    cin.exceptions(cin.failbit);
    cin >> n >> m;
    if (m == 1) {
        cout << 0 << '\n';
        return 0;
    }
    f[1] = mul(m, m - 1);
    for (int i = 2; i <= n; i++) {
        int mm = mul(m - 1, m - 1);
        sub(mm, m - 2);
        f[i] = mul(f[i - 1], mm);
    }
    cout << f[n] << '\n';
}

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