题目:牛牛和牛可乐的赌约

题目分析:这是一个快速幂+逆元的板子题,逆元就是除法,因为计算机不擅长做除法,所以我们需要把它转化成乘法逆元,求逆元可以用费马小定理,这个定理证明了一个公式,我们可以用这个公式求得逆元。

费马小定理:假如p是质数,且(a,p)=1,那么 a(p-1)≡1(mod p)。即:假如a是整数,p是质数,且a,p互质(即两者只有一个公约数1),那么a的(p-1)次方除以p的余数恒等于1。

当涉及取模运算的计算中,如果有除法,不能直接除以一个数,而应该变成乘以它的乘法逆元。

当我们除以一个数n时,也就是乘上1/n,若x是1/n关于模N的逆元,则x=1/n (mod N),即 x*n=1(mod N)。由于我们做题时N常常为1000000007,而1000000007是个素数,

所以它满足了费马小定理,而满足费马小定理说明解唯一,所以我们可以直接得出x*n=n ^ (N-1)。那么x=n^(N-2),即为1/n关于模N的乘法逆元

看懂了上面那么题目就是一个简单的套题了

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod = 1e9 + 7;
const int maxn = 1e6 + 10;
ll fast(ll a, ll b)
{
    ll ans = 1;
    while (b)
    {
        if (b & 1)
            ans = (ans * a) % mod;
        a = (a * a) % mod;
        b >>= 1;
    }
    return ans;
}
ll inv(ll b)
{
    return fast(b, mod - 2) % mod;
}
int main()
{
    ll t, n, m;
    scanf("%lld", &t);
    while (t--)
    {
        scanf("%lld%lld", &n, &m);
        ll x = inv(n);
        printf("%lld\n", (mod + 1 - fast(x, m)) % mod);
    }
}
时间并不会因为你的迷茫和迟疑而停留,就在你看这篇文章的同时,不知道有多少人在冥思苦想,在为算法废寝忘食,不知道有多少人在狂热地拍着代码,不知道又有多少提交一遍又一遍地刷新着OJ的status页面…… 没有谁生来就是神牛,而千里之行,始于足下!