码迷,mamicode.com
首页 > Web开发 > 详细

【hdu 1061】Rightmost Digit(水题 快速幂 分治)

时间:2019-09-04 13:38:24      阅读:95      评论:0      收藏:0      [点我收藏+]

标签:++   分治   name   mod   using   return   hdu 1061   end   偶数   

题目分析:

虽然只要求pow(x,x)%10,但是思路和求快速幂pow(x,y)%mod一样。

前者相当于后者的简化版。

解题思路

  1. 若次数y为1,则pow(x,1)%mod = x%mod;
  2. 若次数y为奇数2n+1,可求出pow(x,n),pow(x,y) = pow(x,n) * pow(x,n) * x
  3. 若次数y为偶数2n,可求出pow(x,n),pow(x,y) = pow(x,n) * pow(x,n)

代码如下(G++):

#include <bits\stdc++.h>

using namespace std;
typedef long long ll;
ll mod = 10;

//快速幂求pow(x,y)%mod
ll pow_mod(ll x, ll y) {
    //若次数y为1,则pow(x,1)%mod = x%mod;
    if (y == 1) return x;
    
    //若次数y为奇数2n+1,可求出pow(x,n),pow(x,y) = pow(x,n)*pow(x,n)*x
    //若次数y为偶数2n,可求出pow(x,n),pow(x,y) = pow(x,n)*pow(x,n)
    ll p = pow_mod(x, y / 2) % mod;
    if (y % 2) return (p * p * x) % mod;
    else return (p * p) % mod;
}

int main() {
    int t;
    cin >> t;
    while (t--) {
        ll n;
        cin >> n;
        cout << pow_mod(n, n) << endl;
    }
    return 0;
}

【hdu 1061】Rightmost Digit(水题 快速幂 分治)

标签:++   分治   name   mod   using   return   hdu 1061   end   偶数   

原文地址:https://www.cnblogs.com/zhangjiuding/p/11458437.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!