HDU6256 Master of Phi (狄利克雷卷积、欧拉函数)

UPC5044
#include <iostream>
#include <bits/stdc++.h>

using namespace std;
const int maxn = 1e6 + 100;
const int inf = 0x3f3f3f3f;
const int mod = 998244353;
typedef long long ll;

ll powmod(ll a, ll b) {
    ll ret = 1;
    while (b) {
        if (b & 1) ret = ret * a % mod;
        a = a * a % mod;
        b >>= 1;
    }
    return ret;
}


int main() {
    freopen("input.txt", "r", stdin);
    int _;
    scanf("%d", &_);
    while (_--) {
        int n;
        ll p, q;
        ll ans = 1;
        scanf("%d", &n);
        while (n--) {
            scanf("%lld %lld", &p, &q);
            ll temp = (p + (p - 1) * q) % mod;
            temp = temp * powmod(p, q - 1) % mod;
            ans = ans * temp % mod;
        }
        printf("%lld\n", ans);
    }
    return 0;
}

 

posted @ 2019-04-05 20:59  Albert_liu  阅读(256)  评论(0编辑  收藏  举报